React面试题之setState的执行机制

setState 是 React 中用于更新组件状态的方法。

1. setState 的基本用法

在 React 类组件中,你可以使用 setState 来更新组件的状态。setState 接受一个对象或一个返回对象的函数作为参数

2. 合并状态更新

当调用 setState 时,React 不会立即更新 this.state。相反,React 会将状态更新请求放入队列中,并进行合并。

复制代码
this.setState({ count: 1 });
this.setState({ count: 2 });

3.同步异步

setState在合成事件和生命周期函数中是异步的,在原生事件和定时器中都是同步的。

setState本身不分同步或者异步,而是取决于是否处于batch update中。组件中的所有函数在执行时临时设置一个变量isBatchingUpdates = true,当遇到setState时,如果isBatchingUpdates是true,那么setState就是异步的,如果是false,那么setState就是同步的。那么什么时候isBatchingUpdates会被设置成false呢?

1当函数运行结束时isBatchingUpdates = false

2 当函数遇到setTimeout、setInterval时isBatchingUpdates = false

3 当dom添加自定义事件时isBatchingUpdates = false

相关推荐
Json____2 分钟前
学法减分交管12123模拟练习小程序源码前端和后端和搭建教程
前端·后端·学习·小程序·uni-app·学法减分·驾考题库
迂 幵10 分钟前
vue el-table 超出隐藏移入弹窗显示
javascript·vue.js·elementui
上趣工作室15 分钟前
vue2在el-dialog打开的时候使该el-dialog中的某个输入框获得焦点方法总结
前端·javascript·vue.js
家里有只小肥猫15 分钟前
el-tree 父节点隐藏
前端·javascript·vue.js
fkalis16 分钟前
【海外SRC漏洞挖掘】谷歌语法发现XSS+Waf Bypass
前端·xss
陈随易1 小时前
农村程序员-关于小孩教育的思考
前端·后端·程序员
云深时现月1 小时前
jenkins使用cli发行uni-app到h5
前端·uni-app·jenkins
昨天今天明天好多天1 小时前
【Node.js]
前端·node.js
亿牛云爬虫专家2 小时前
Puppeteer教程:使用CSS选择器点击和爬取动态数据
javascript·css·爬虫·爬虫代理·puppeteer·代理ip
2401_857610032 小时前
深入探索React合成事件(SyntheticEvent):跨浏览器的事件处理利器
前端·javascript·react.js