zoukankan      html  css  js  c++  java
  • 对于react中的this.setState的理解

    一、this.setState第二个参数的作用:修改数据更新后最新的DOM结构
    二、this.setState为什么是异步的?
    1.setState只在合成事件和钩子函数中是“异步”的,在原生事件和setTimeout中都是同步的。
    2.setState的“异步”并不是说内部由异步代码实现,其实本身执行的过程和代码都是同步的,
    只是合成事件和钩子函数的调用顺序在更新之前,导致在合成事件和钩子函数中没法立马拿到更新后的值,形式了所谓的“异步”,当
    然可以通过第二个参数setState(partialState,callback)中的callback拿到更新后的结果。
    3.setState的批量更新优化也是建立在“异步”(合成事件、钩子函数)之上的,
    在原生事件和setTimeout中不会批量更新,在“异步”中如果对同一个值进行多次setState,setState的批量更新策略会对其进行覆盖,取最后一次的执行,
    如果是同时setState多个不同的值,在更新时会对其进行合并批量更新。
  • 相关阅读:
    c++数据类型
    c++注释
    c++基本语法
    c++环境配置
    c++简介
    9 HTTP和HTTPS
    12 RESTful架构(SOAP,RPC)
    剑指10二进制中1的个数
    第2章 新手必须掌握的Linux命令
    11个炫酷的Linux终端命令大全
  • 原文地址:https://www.cnblogs.com/Leslie-Cheung1584304774/p/10734690.html
Copyright © 2011-2022 走看看