06 React 中你不知道的this.setState
16==》 this.setStat是批量执行的 它发现做三次是多余的,所以只执行一次
import React, { Component } from "react"; export default class StaTest extends Component { state = { nun: 1 }; componentDidMount() { // this.setStat是批量执行的 它发现做三次是多余的,所以只执行一次 this.setState({ nun: this.state.nun + 1 }); this.setState({ nun: this.state.nun + 1 }); this.setState({ nun: this.state.nun + 1 }); } render() { return ( <div> {/* 获取state中的值 最终为2*/} {this.state.nun} </div> ); } }
如何让他执行三次 更改为this.setState this.setState(prevState=>{ return{ nun:prevState.nun+1 } }) this.setState(prevState => { return { nun: prevState.nun + 1 } }) this.setState(prevState => { return { nun: prevState.nun + 1 } }) 可以优化为 this.setState(prevState => ({ nun: prevState.nun + 1 }))
遇见问题,这是你成长的机会,如果你能够解决,这就是收获。
作者:晚来南风晚相识
出处:https://www.cnblogs.com/IwishIcould/
本文版权归作者所有,欢迎转载,未经作者同意须保留此段声明,在文章页面明显位置给出原文连接
如果文中有什么错误,欢迎指出。以免更多的人被误导。
出处:https://www.cnblogs.com/IwishIcould/
想问问题,打赏了卑微的博主,求求你备注一下的扣扣或者微信;这样我好联系你;(っ•̀ω•́)っ✎⁾⁾!
如果觉得这篇文章对你有小小的帮助的话,记得在右下角点个“推荐”哦,或者关注博主,在此感谢!
万水千山总是情,打赏5毛买辣条行不行,所以如果你心情还比较高兴,也是可以扫码打赏博主(っ•̀ω•́)っ✎⁾⁾!
想问问题,打赏了卑微的博主,求求你备注一下的扣扣或者微信;这样我好联系你;(っ•̀ω•́)っ✎⁾⁾!
![](http://images.cnblogs.com/cnblogs_com/IwishIcould/1900124/t_201214043958支付宝收款码.jpg?a=1607924145179)
支付宝
![](http://images.cnblogs.com/cnblogs_com/IwishIcould/1900124/t_20121604194271E6E296CCB71A007F4E22073D5EB64A.jpg)
微信
如果文中有什么错误,欢迎指出。以免更多的人被误导。