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

setState的参数

目录

 1、setState的第一个参数

  2、setState的第二个参数

 3、在 React 底层主要做了那些事呢?

 4、类组件如何限制 state 更新视图


 React 项目中的 UI 的改变来源于 State 改变,类组件中 setState 是更新组件,渲染视图的

 1、setState的第一个参数

setState(obj,callback)

第一个参数:

        1.  如果 obj 是一个对象,则为即将合并的 state;

        2.  如果 obj 是一个函数,那么当前组件的 state 和 props 将作为参数,返回值用于 合并新的 state。
 

export default class A extends React.PureComponent {
    constructor(props){
        super(props)
        this.state={
            number: 0,
        }
    }

componentDidMpunt () {

    // 第一个参数为object类型的时候
    this.setState({ 
        number: 1,
    })

}

    render () {
        // 工作中常用到的写法
        console.log(this.state,number, 'number') // 1
        return (
        )
     }

}
 

  2、setState的第二个参数

 第二个参数:

         callback 为一个函数,函数执行上下文中可以获取当前 setState 更新后的最新 state 的值,可以作为以来 state 变化的副作用函数,可以 用来做一些基本的 DOM 操作等。

export default class A extends React.PureComponent {
    constructor(props){
        super(props)
        this.state={
            number: 0,
        }
    }

componentDidMpunt () {

    // 第一个参数为object类型的时候
    this.setState({ number: 1 }, () => {
        console.log(this.state.number) // 1  获取最新的number 
    })

    
    // 第一个参数为function类型的时候
    this.setState((state, props) => {
        return { 
            number: state.number + 2
        }
    }, () => {
        console.log(this.state.number) // 2  获取最新的number 
    })


    // 工作中常用到的写法
    this.setState({
        number: 3,
    })
    

}

    render () {
        // 工作中常用到的写法
        console.log(this.state,number, 'number') // 3
        return (
        )
     }



}
 

 3、在 React 底层主要做了那些事呢?

 假如一次事件中触发一次如上 setState ,在 React 底层主要做了那些事呢?

  • 首先,setState 会产生当前更新的优先级(老版本用 expirationTime ,新版本用 lane )。
  • 接下来 React 会从 fiber Root 根部 fiber 向下调和子节点,调和阶段将对比发生更新的地方,更新对比 expirationTime ,找到发生更新的组件,合并 state,然后触发 render 函数,得到新的 UI 视图层,完成 render 阶段。
  • 接下来到 commit 阶段,commit 阶段,替换真实 DOM ,完成此次更新流程。
  • 此时仍然在 commit 阶段,会执行 setState 中 callback 函数,如上的()=>{ console.log(this.state.number) },到此为止完成了一次 setState 全过程。

更新流程图如下:

              

主要任务的渲染先后顺序

render 阶段 render 函数执行 -> commit 阶段真实 DOM 替换 -> setState 回调函数执行 callback 。

 4、类组件如何限制 state 更新视图

 对于类组件如何限制 state 带来的更新作用的呢?

  • ① pureComponent 可以对 state 和 props 进行浅比较,如果没有发生变化,那么组件不更新。
  • ② shouldComponentUpdate 生命周期可以通过判断前后 state 变化来决定组件需不需要更新,需要更新返回true,否则返回false。


http://www.kler.cn/a/229068.html

相关文章:

  • 初识go语言之指针用法
  • 数据库的DML
  • doris: Flink导入数据
  • 1.8 GPT-4:开创人工智能的新纪元
  • 【Mysql进阶知识】Mysql 程序的介绍、选项在命令行配置文件的使用、选项在配置文件中的语法
  • PL/SQL语言的语法糖
  • 2 月 5 日算法练习- 字符串
  • easyexcel解析跨多行的数据
  • Linux 【docker系列1 - docker 安装与使用】
  • 解决hive表新增的字段查询为空null问题
  • 2.5 作业
  • 从 AGP 4.1.2 升级到 7.5.1——动态添加仓库
  • 【Java】小白友好的MyBatis基础XML开发学习笔记
  • 什么是Java中的弱引用(Weak Reference)和软引用(Soft Reference)?
  • 【漏洞复现】大华智慧园区综合管理平台bitmap接口存在任意文件上传漏洞
  • 某赛通电子文档安全管理系统 UploadFileToCatalog SQL注入漏洞复现
  • 问题:塑瓷后的牙冠要比完成的牙冠大() #学习方法#其他
  • Java入门之JavaSe(韩顺平p1-p?)
  • AI应用开发-python实现redis数据存储
  • LeetCode、1137. 第 N 个泰波那契数【简单,动态规划】
  • 十分钟掌握Go语言==运算符与reflect.DeepEqual函数处理interface{}值的比较规则
  • C++泛型编程:类模板(下)
  • 【Iceberg学习一】什么是Iceberg?
  • 飞天使-k8s知识点12-kubernetes散装知识点1-架构有状态资源对象分类
  • PostgreSQL解决序列(自增id)自动增长冲突
  • 电路设计(10)——超温报警电路的proteus仿真