当前位置: 首页 > news >正文

HarmonyOS NEXT零基础入门到实战-第二部分

HarmonyOS NEXT零基础入门到实战-第二部分
Swiper 轮播组件
Swiper是一个 容器 组件,当设置了多个子组件后,可以对这些 子组件 进行轮播显示。(文字、图片...)
1、Swiper基本语法
2、Swiper常见属性
3、Swiper样式自定义
4、案例:小米有品
5、作业:手机淘宝

Swiper相关源代码:
@Entry
@Component
struct Index {
  build() {
    Column() {
      // Swiper 包内容,设尺寸
      Swiper() {
        Text('1')
          .backgroundColor(Color.Orange)
        Text('2')
          .backgroundColor(Color.Yellow)
        Text('3')
          .backgroundColor(Color.Brown)
      }
      .width('100%')
      // .height(300)
      .aspectRatio(2.4) // 设置和图片一致的宽高比,保证图片正常适配
      // 常见属性
      .loop(true) // 开启循环
      .autoPlay(true) // 自动播放,默认3s
      .interval(5000) // 自动轮播间隔
      .vertical(false) // 横向/纵向
      // 定制小圆点
      // .indicator(false)
      .indicator(
        Indicator.dot() // 小圆点
          .itemWidth(10) // 默认的宽
          .itemHeight(5) // 默认的高
          // .color(Color.Gray) // 默认的颜色
          .selectedItemWidth(30) // 选中的宽
          .selectedItemHeight(5) // 选中的高
          .selectedColor(Color.White) // 选中的颜色
      )

      Swiper() {
        Image($r('app.media.hw'))
          .objectFit(ImageFit.Cover)
        Image($r('app.media.pg'))
          .objectFit(ImageFit.Cover)
        Image($r('app.media.xm'))
          .objectFit(ImageFit.Cover)
      }
      .width('100%')
      .height(300)
      .loop(true) // 开启循环
      .autoPlay(true) // 自动播放,默认3s
      .interval(5000) // 自动轮播间隔
    }
  }
}

样式&结构重用
@Extend:扩展组件(样式、事件)
比如:
@Extend(Text)
function bannerItem(bgColor: ResourceColor, msg: string) {
  .fontSize(30)
  .fontColor(Color.White)
  .backgroundColor(bgColor)
  .textAlign(TextAlign.Center)
  .onClick(() => {
    AlertDialog.show({
      message: msg
    })
  })
}

   Swiper() {
        Text('1')
          .bannerItem(Color.Orange, '轮播图 1')
        Text('2')
          .bannerItem(Color.Brown, '轮播图 2')
        Text('3')
          .bannerItem(Color.Green, '轮播图 3')
      }

@Styles:抽取通用属性、事件
针对所有组件的公有属性,比如说宽高、背景色、点击事件等,@Styles不支持传参
1、全局定义(不支持this.调用)
@Styles function commonStyles() {
    .width(100)
    .height(100)
    .onClick(() => { ... })
}
2、在组件内定义(省略function) 才能通过this访问到自己的状态 这种使用相对全局使用较多
@Styles setBg() {
    .backgroundColor(Color.Red)
}

@Builder:自定义构建函数(结构、样式、事件)


// 全局 Builder
@Builder
function navItem(icon: ResourceStr, txt: string) {
  Column({space: 10}) {
    Image(icon)
      .width('80%')
    Text(txt)
  }
  .width('25%')
  .onClick(() => {
    AlertDialog.show({
      message: '点了' + txt
    })
  })
}

@Entry
@Component
struct Index {
  @State builderStr: string = '@Builder'
  
  // 局部builder 只能定义在组件内 this.xxx
  @Builder
  navItem(icon: ResourceStr, txt: string) {
  Column({space: 10}) {
    Image(icon)
      .width('80%')
    Text(txt)
  }
  .width('25%')
  .onClick(() => {
    AlertDialog.show({
      message: '点了' + txt + this.builderStr
    })
  })
}

  build() {
    Column() {
      Row() {
        navItem($r('app.media.xm'), '小米手机')
        navItem($r('app.media.hw'), '华为手机')
        this.navItem($r('app.media.pg'), '苹果手机')
      }
    }
  }
}

总结
@Extend  抽取 特定组件 样式、事件   可以传递参数
@Styles    抽取 公共样式、事件           不可以传递参数
@Builder  抽取结构、样式、事件         可以传递参数

滚动容器Scroll
当子组件的布局尺寸超过Scroll的尺寸时,内容可以滚动
学习目录:
1、Scroll 的核心用法
2、Scroll 的常见属性
3、Scroll 的控制器
4、Scroll 的事件
5、案例:京东案例实战
源代码:

@Entry
@Component
struct Index {

  build() {
    Column() {
      // 如果希望内容溢出,能够滚动
      Scroll() {
        Column({space: 10}) {
          ForEach(Array.from({length: 10}), (item: string, index: number) => {
            Text('测试文本' + (index + 1))
              .width('100%')
              .height(100)
              .textAlign(TextAlign.Center)
              .backgroundColor(Color.Orange)
              .fontSize(20)
              .fontColor(Color.White)
              .borderRadius(20)
          })
        }
        .padding(10)
        .width('100%')
      }
      // .scrollable(ScrollDirection.Horizontal)
      // .scrollBar(BarState.Auto)
      // .scrollBarColor(Color.Blue)
      // .scrollBarWidth(5)
      .edgeEffect(EdgeEffect.Spring)  // 滑动效果:弹簧
    }
    .width('100%')
    .height(200)
  }
}


  
Scroll的控制器:
核心步骤:
1、实例化 Scroller 的控制器
2、绑定给 Scroll 组件    
3、控制器的方法 控制滚动, 控制器属性 获取滚动距离

Scroll 事件:
Scroll 组件提供了一些事件,让开发者可以在适当的时候添加逻辑
Scroll(){
}
.onScroll((x, y) => {
    // 滚动时一直触发 可以结合 scroller的currentOffset方法 获取滚动距离
})
.onWillScroll((offset: number) => {
   console.log('onWillScroll 已经滑动的距离', this.myScroller.currentOffset().yOffset + offset)
})
 .onScroll((x, y) => {
   console.log('onScroll 已经滑动的距离', this.myScroller.currentOffset().yOffset)
})

滚动容器Scroll - 京东案例实战
需求说明:
1、点击火箭回到顶部
2、火箭显示效果切换
    2.1 默认隐藏
    2.2 超过400 ---->显示,反之--->隐藏
@State yOffset : number = 0;
 .onScroll((x, y) => {
   yOffset = this.myScroller.currentOffset().yOffset
})

if(yOffset > 400) {
    // 渲染
}

源代码:

@Entry
@Component
struct Index {
  // 1、创建 Scroller 对象(实例化)
  myScroller: Scroller = new Scroller()

  build() {
    Column() {
      // 如果希望内容溢出,能够滚动
      // 2、绑定给 Scroll 组件
      Scroll(this.myScroller) {
        Column({space: 10}) {
          ForEach(Array.from({length: 10}), (item: string, index: number) => {
            Text('测试文本' + (index + 1))
              .width('100%')
              .height(100)
              .textAlign(TextAlign.Center)
              .backgroundColor(Color.Orange)
              .fontSize(20)
              .fontColor(Color.White)
              .borderRadius(20)
          })
        }
        .padding(10)
        .width('100%')
      }
      .width('100%')
      .height(400)
      // .scrollable(ScrollDirection.Horizontal)
      // .scrollBar(BarState.Auto)
      // .scrollBarColor(Color.Blue)
      // .scrollBarWidth(5)
      .edgeEffect(EdgeEffect.Spring)  // 滑动效果:弹簧
      .onWillScroll((offset: number) => {
        console.log('onWillScroll 已经滑动的距离', this.myScroller.currentOffset().yOffset + offset)
      })
      .onScroll((x, y) => {
        console.log('onScroll 已经滑动的距离', this.myScroller.currentOffset().yOffset)
      })

      Button('控制滚动条位置').margin(20)
        .onClick(() => {
          this.myScroller.scrollEdge(Edge.Top) // 会滚动顶部
        })
      Button('获取已经滚动的距离')
        .onClick(() => {
          const y = this.myScroller.currentOffset().yOffset
          AlertDialog.show({
            message: `y:${y}`
          })
        })
    }
  }
}

==== 
容器组件 Tabs
当页面内容较多时,可以通过Tabs组件进行 分类展示
学习目录:
1、Tabs 基本用法
2、Tabs 常见属性
3、滚动导航栏
4、自定义TabBar
5、案例: 小米有品底部Tabs

源代码:

@Entry
@Component
struct Index {
  titles: string[] = [
    '首页', '关注', '热门', '军事','体育',
    '八卦', '数码', '财经', '美食','旅行'
  ]
  build() {
    Column() {
      // 调整位置 顶部或者底部(参数)
      Tabs({barPosition: BarPosition.Start}) {
        ForEach(this.titles, (item: string, index) => {
          TabContent() {
            Text(`${item}内容`)
          }
          .tabBar(item)
        })
      }
      .vertical(false)  // 调整导航水平或者垂直
      .scrollable(true) // 是否开启手势滑动
      .animationDuration(0) // 点击滑动动画时间
      .barMode(BarMode.Scrollable) // 滚动导航栏
    }
  }
}

自定义的TabBar
1、基础结构 2、高亮切换
源代码:

@Entry
@Component
struct Index {
  // 准备状态,存储激活的索引
  @State selectedIndex: number = 0;

  build() {
    // 调整位置 顶部或者底部(参数)
    Tabs({barPosition: BarPosition.End}) {
      TabContent() {
        Text('购物车')
      }
      .tabBar(this.myBuilder(0, '购物车', $r('app.media.startIcon'), $r('app.media.xm')))
      TabContent() {
        Text('我的')
      }
      .tabBar(this.myBuilder(1, '我的',  $r('app.media.startIcon'), $r('app.media.hw')))
    }
    // .vertical(false)  // 调整导航水平或者垂直
    // .scrollable(true) // 是否开启手势滑动
    // .animationDuration(0) // 点击滑动动画时间
    // .barMode(BarMode.Scrollable) // 滚动导航栏
    .onChange((index: number) => {
      this.selectedIndex = index
    })

  }

  @Builder
  myBuilder(itemIndex: number,title: string, img: ResourceStr, selectedImg: ResourceStr) {
    Column() {
      Image(itemIndex == this.selectedIndex ? selectedImg : img)
        .width(30)
      Text(title)
        .fontColor(itemIndex == this.selectedIndex ? Color.Red : Color.Black)
    }
  }
}

案例 小米有品底部Tabs:
实现思路:
1、基础结构  2、高亮控制 3、中间特殊结构
源代码:
@Entry
@Component
struct Index {
  // 准备状态,存储激活的索引
  @State selectedIndex: number = 0;

  build() {
    // 调整位置 顶部或者底部(参数)
    Tabs({barPosition: BarPosition.End}) {
      TabContent() {
        Text('购物车')
      }
      .tabBar(this.myBuilder(0, '购物车', $r('app.media.startIcon'), $r('app.media.xm')))

      // 特殊形状的Tab
      TabContent(){
        Text('活动内容')
      }
      .tabBar(this.centerBuilder())

      TabContent() {
        Text('我的')
      }
      .tabBar(this.myBuilder(2, '我的',  $r('app.media.startIcon'), $r('app.media.hw')))
    }
    // .vertical(false)  // 调整导航水平或者垂直
    // .scrollable(true) // 是否开启手势滑动
    // .animationDuration(0) // 点击滑动动画时间
    // .barMode(BarMode.Scrollable) // 滚动导航栏
    .onChange((index: number) => {
      this.selectedIndex = index
    })

  }

  @Builder
  myBuilder(itemIndex: number,title: string, img: ResourceStr, selectedImg: ResourceStr) {
    Column() {
      Image(itemIndex == this.selectedIndex ? selectedImg : img)
        .width(30)
      Text(title)
        .fontColor(itemIndex == this.selectedIndex ? Color.Red : Color.Black)
    }
  }

  @Builder
  centerBuilder() {
    Image($r('app.media.pg'))
      .width(30)
      .height(30)
      .margin({bottom: 20})
  }
}


 

相关文章:

HarmonyOS NEXT零基础入门到实战-第二部分

HarmonyOS NEXT零基础入门到实战-第二部分 Swiper 轮播组件 Swiper是一个 容器 组件,当设置了多个子组件后,可以对这些 子组件 进行轮播显示。(文字、图片...) 1、Swiper基本语法 2、Swiper常见属性 3、Swiper样式自定义 4、案例&…...

《小程序02:云开发之增删改查》

一、前置操作 // 一定要用这个符号包含里面的${}才会生效 wx.showToast({title: 获取数据成功:${colorLista}, })1.1:初始化介绍 **1、获取数据库引用:**在开始使用数据库 API 进行增删改查操作之前,需要先获取数据库的引用 cons…...

SQL执行流程、SQL执行计划、SQL优化

select查询语句 select查询语句中join连接是如何工作的? 1、INNER JOIN 返回两个表中的匹配行。 2、LEFT JOIN 返回左表中的所有记录以及右表中的匹配记录。 3、RIGHT JOIN 返回右表中的所有记录以及左表中的匹配记录。 4、FULL OUTER JOIN 返回左侧或右侧表中有匹…...

【前端】JavaScript入门及实战41-45

文章目录 41 嵌套的for循环42 for循环嵌套练习(1)43 for循环嵌套练习(2)44 break和continue45 质数练习补充 41 嵌套的for循环 <!DOCTYPE html> <html> <head> <title></title> <meta charset "utf-8"> <script type"…...

更加深入Mysql-04-MySQL 多表查询与事务的操作

文章目录 多表查询内连接隐式内连接显示内连接 外连接左外连接右外连接 子查询 事务事务隔离级别 多表查询 有时我们不仅需要一个表的数据&#xff0c;数据可能关联到俩个表或者三个表&#xff0c;这时我们就要进行夺标查询了。 数据准备&#xff1a; 创建一个部门表并且插入…...

基于最新版的flutter pointycastle: ^3.9.1的AES加密

基于最新版的flutter pointycastle: ^3.9.1的AES加密 自己添加pointycastle: ^3.9.1库config.dartaes_encrypt.dart 自己添加pointycastle: ^3.9.1库 config.dart import dart:convert; import dart:typed_data;class Config {static String password 成都推理计算科技; // …...

K8S内存资源配置

在 Kubernetes (k8s) 中&#xff0c;资源请求和限制用于管理容器的 CPU 和内存资源。配置 CPU 和内存资源时&#xff0c;使用特定的单位来表示资源的数量。 CPU 资源配置 CPU 单位&#xff1a;Kubernetes 中的 CPU 资源以 “核” (cores) 为单位。1 CPU 核心等于 1 vCPU/Core…...

【多任务YOLO】 A-YOLOM: You Only Look at Once for Real-Time and Generic Multi-Task

You Only Look at Once for Real-Time and Generic Multi-Task 论文链接&#xff1a;http://arxiv.org/abs/2310.01641 代码链接&#xff1a;https://github.com/JiayuanWang-JW/YOLOv8-multi-task 一、摘要 高精度、轻量级和实时响应性是实现自动驾驶的三个基本要求。本研究…...

数学建模--灰色关联分析法

目录 简介 基本原理 应用场景 优缺点 优点&#xff1a; 缺点&#xff1a; 延伸 灰色关联分析法在水质评价中的具体应用案例是什么&#xff1f; 如何克服灰色关联分析法在主观性强时的数据处理和改进方法&#xff1f; 灰色关联分析法与其他系统分析方法&#xff08;如A…...

NetSuite Saved Search迁移工具

我们需要在系统间迁移Saved Search&#xff0c;但是采用Copy To Account或者Bundle时&#xff0c;会有一些Translation不能迁移&#xff0c;或者很多莫名其妙的Dependency&#xff0c;导致迁移失败。因此&#xff0c;我们想另辟蹊径&#xff0c;借助代码完成Saved Search的迁移…...

Java IO模型深入解析:BIO、NIO与AIO

Java IO模型深入解析&#xff1a;BIO、NIO与AIO 一. 前言 在Java编程中&#xff0c;IO&#xff08;Input/Output&#xff09;操作是不可或缺的一部分&#xff0c;它涉及到文件读写、网络通信等方面。Java提供了多种类和API来支持这些操作。本文将从IO的基础知识讲起&#xff…...

《从C/C++到Java入门指南》- 9.字符和字符串

字符和字符串 字符类型 Java 中一个字符保存一个Unicode字符&#xff0c;所以一个中文和一个英文字母都占用两个字节。 // 计算1 .. 100 public class Hello {public static void main(String[] args) {char a A;char b 中;System.out.println(a);System.out.println(b)…...

Adobe国际认证详解-视频剪辑

在数字化时代&#xff0c;视频剪辑已成为创意表达和视觉传播的重要手段。随着技术的不断进步&#xff0c;熟练掌握视频剪辑技能的专业人才需求日益增长。在这个背景下&#xff0c;Adobe国际认证应运而生&#xff0c;成为全球创意设计领域的重要标杆。 Adobe国际认证是由Adobe公…...

昇思25天学习打卡营第19天|MindNLP ChatGLM-6B StreamChat

文章目录 昇思MindSpore应用实践ChatGML-6B简介基于MindNLP的ChatGLM-6B StreamChat Reference 昇思MindSpore应用实践 本系列文章主要用于记录昇思25天学习打卡营的学习心得。 ChatGML-6B简介 ChatGLM-6B 是由清华大学和智谱AI联合研发的产品&#xff0c;是一个开源的、支持…...

.NET在游戏开发中有哪些成功的案例?

简述 在游戏开发的多彩世界中&#xff0c;技术的选择往往决定了作品的成败。.NET技术&#xff0c;以其跨平台的性能和强大的开发生态&#xff0c;逐渐成为游戏开发者的新宠。本文将带您探索那些利用.NET技术打造出的著名游戏案例&#xff0c;领略.NET在游戏开发中的卓越表现。 …...

搜维尔科技:我们用xsens完成了一系列高难度的运动项目并且捕获动作

我们用xsens完成了一系列高难度的运动项目并且捕获动作 搜维尔科技&#xff1a;我们用xsens完成了一系列高难度的运动项目并且捕获动作...

深入探讨:Node.js、Vue、SSH服务与SSH免密登录

在这篇博客中&#xff0c;我们将深入探讨如何在项目中使用Node.js和Vue&#xff0c;并配置SSH服务以及实现SSH免密登录。我们会一步步地进行讲解&#xff0c;并提供代码示例&#xff0c;确保你能轻松上手。 一、Node.js 与 Vue 的结合 1.1 Node.js 简介 Node.js 是一个基于 …...

Unity UGUI 之 Toggle

​本文仅作学习笔记与交流&#xff0c;不作任何商业用途本文包括但不限于unity官方手册&#xff0c;唐老狮&#xff0c;麦扣教程知识&#xff0c;引用会标记&#xff0c;如有不足还请斧正​ 1.什么是Toggle&#xff1f; Unity - Manual: Toggle 带复选框的开关&#xff0c;可…...

Git报错:error: fsmonitor--daemon failed to start处理方法

问题描述 git用了很久了&#xff0c;但是后面突然发现执行命令时&#xff0c;后面都会出现这个报错&#xff0c;虽然该报错好像不会影响正常的命令逻辑&#xff0c;但是还是感觉有天烦人&#xff0c;就去找了找资料。 $ git status error: fsmonitor--daemon failed to start…...

【项目】星辰博客介绍

目录 一、项目背景 二、项目功能 1. 登录功能&#xff1a; 2. 列表页面&#xff1a; 3. 详情页面&#xff1a; 4. 写博客&#xff1a; 三、技术实现 四、功能页面展示 1. 用户登录 2. 博客列表页 3. 博客编辑更新页 4.博客发表页 5. 博客详情页 五.系统亮点 1.强…...

从0开始的STM32HAL库学习6

外部时钟源选择 配置环境 选择TIM2 配置红色框图中的各种配置 时钟源选择外部时钟 2 1. 预分频器 Prescaler &#xff0c;下面填0&#xff0c;不分频 2. 计数模式 CounterModer &#xff0c;计数模式选择为向上计数 3. 自动重装寄存器 CouterPeriod &#xff0c;自动重…...

Elasticsearch ILM 热节点迁移至冷节点 IO 打满、影响读写解决方案探讨

1、实战问题 ILM&#xff08;索引生命周期管理&#xff09; 遇到热数据迁移至冷节点时造成 IO 打满影响读写的情况。 现在采取的方案是调整索引生命周期策略&#xff0c;定时的将Cold phase 开启/关闭。低峰开启&#xff0c;高峰关闭。 就是不知道这里面会有啥坑。 热节点&…...

STM32中PC13引脚可以当做普通引脚使用吗?如何配置STM32的TAMPER?

1.STM32中PC13引脚可以当做普通引脚使用吗&#xff1f; 在STM32单片机中&#xff0c;PC13引脚可以作为普通IO使用&#xff0c;但需要进行一定的配置。PC13通常与RTC侵入检测功能&#xff08;TAMPER&#xff09;复用&#xff0c;因此需要关闭TAMPER功能才能将其作为普通IO使用。…...

k8s学习——创建测试镜像

创建一个安装了ifconfig、telnet、curl、nc、traceroute、ping、nslookup等网络工具的镜像&#xff0c;便于集群中的测试。 创建一个Dockerfile文件 # 使用代理下载 Ubuntu 镜像作为基础 FROM docker.m.daocloud.io/library/ubuntu:latest# 设置环境变量 DEBIAN_FRONTEND 为 …...

重塑水资源管理的新篇章:深度剖析智慧水利解决方案的前沿技术与应用,探索其如何推动水利行业向智能化、高效化、可持续化方向迈进

目录 一、引言 二、智慧水利的核心技术 1、物联网技术 2、大数据与云计算 3、人工智能与机器学习 4、数字孪生技术 三、智慧水利的应用实践 1、智慧河湖长制信息平台 2、智能灌溉系统 3、城市防洪排涝智慧管理系统 4、智慧水库建设 四、智慧水利的推动作用 1、提升…...

C#实现数据采集系统-查询报文处理和响应报文分析处理

发送报文处理 增加一个功能码映射关系 //功能码映射关系public readonly Dictionary<string, byte> ReadFuncCodes = new Dictionary<string, byte>();<...

【音视频】AAC编码器与ffmpeg生成AAC数据

文章目录 前言为什么使用AAC&#xff1f;AAC规格常见的AAC规格规格之间的区别 ffmpeg生成AAC数据 总结 前言 在音频压缩技术不断发展的过程中&#xff0c;AAC&#xff08;Advanced Audio Coding&#xff09;编码器因其出色的音质和压缩效率&#xff0c;逐渐成为数字音频领域的…...

Linux openEuler_24.03部署MySQL_8.4.0 LTS安装实测验证安装以及测试连接全过程实操手册

Linux openEuler_24.03部署MySQL_8.4.0 LTS安装实测验证安装以及测试连接全过程实操手册 前言: 什么是 MySQL? MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于Oracle 公司。MySQL 是一种关系型数据库管理系统,关系型数据库将数据保存在不同的表中,…...

【Elasticsearch7】3-基本操作

目录 RESTful 数据格式 HTTP操作 索引操作 倒排索引 创建索引 查看所有索引 查看单个索引 删除索引 文档操作 创建文档 查看文档 ​编辑 全量修改 ​编辑局部修改 删除文档 条件删除文档 高级查询 条件查询 URL带参查询 请求体带参查询 带请求体方式的查…...

给定一整数数组,其中有p种数出现了奇数次,其他数都出现了偶数次,怎么找到这p个数?

给定一长度为m的整数数组 &#xff0c;其中有p种不为0的数出现了奇数次&#xff0c;其他数都出现了偶数次&#xff0c;找到这p个数。 要求&#xff1a;时间复杂度不大于O(n)&#xff0c;空间复杂度不大于O(1)。 由于时间复杂度不大于O(n)&#xff0c;则不能在遍历数组中嵌套遍…...

asp伪静态网站如何做筛选/网站标题seo外包优化

承接上文&#xff1a; Docker进阶篇教程&#xff0c;docker-compose, docker swarm, 弹性、扩缩容 Docker进阶篇教程9. 体会swarm弹性、扩缩容9.1 理解扩缩容9.2 docker service命令9.3 理解灰度发布9.4 replicas 3个副本测试9.5 replicas 10个副本测试9.6 scale命令扩缩容1…...

黑科技软件网站/推广公司是做什么的

一. 静态库的生成 1. 测试目录: lib 2. 源码文件名: mywindow.h, mywindow.cpp, 类MyWindow继承于QPushButton, 并将文字设置为"Im in class MyWindow"; 3. 编写项目文件: mywindow.pro 注意两点: TEMPLATE lib CONFIG staticlib …...

做区块链在哪个网站/培训报名

在实际开发中&#xff0c;项目经理会一直强调一句话&#xff0c;永远不要相信客户端的数据(前端可以不用验证&#xff0c;但是后端必须验证)。大家同意这样的说法吧。。新端验证毋庸质疑JS验证&#xff0c;提高用户体验我们不得不添加一些与后端一致的验证逻辑&#xff0c;同样…...

做软件贵还是做网站贵/国内seo服务商

目录 用户管理用户管理 主要为了控制权限&#xff0c;让不同开发者&#xff0c;仅能操作属于自己的业务范围内的数据 创建mysql账户 账户中涉及的三个数据 账户名、密码、ip地址 ip是用于限制某个账户只能在哪个机器上登录------------------------第一种方式-----------------…...

个人备案 可以做企业网站吗/新闻发布的网站

影任有料&#xff0c;总有一款是你想要影任J作为一个不资深且跑路的程序猿&#xff0c;今天要跟大家讲的算是一个行业小技巧&#xff0c;请各位搬好小板凳仔细听吧&#xff01;F12作为一个多功能按键&#xff0c;在职场有着特殊的运用&#xff0c;比如说扒图、改网页上的内容、…...

中英双语网站怎么做/免费模式营销案例

provide与inject1. provide与inject用法2.使用示例3.provide与inject实现双向绑定vue 组件间的通信方式有很多种&#xff0c;所以使用时需要考虑哪种方式是最合适的。若仅仅是简单的隔代组件通信&#xff0c;我认为使用 provide与inject会更加方便。1. provide与inject用法 作…...