react中怎么获取state


本文摘自PHP中文网,作者藏色散人,侵删。

react中获取state的方法:首先打开相应的react代码文件;然后在react中可以通过“this.state.{属性}”的方式直接获取state即可。

本教程操作环境:windows7系统、react17.0.1版本、Dell G3电脑。

react中怎么获取state

在react中可以通过this.state.{属性}的方式直接获取state,但是当我们修改state的时候,往往有许多的坑需要注意。

以下为三种常见的陷阱:

1、不能直接修改state。

组件修改state,并不会重新触发render。列如:

1

2

3

4

5

//错误

this.state.title='React';

正确修改方式是使用setState();

//正确

this.setState({title:'React'});

2、state的更新时异步的

调用setState时,组件state并不会立即改变,只是把要修改的状态放入事件队列当中,而react会优化真正的执行时机,并且处于本身的性能原因,可能会将多次setState的状态修改合并成一次状态修改。因此不要依靠当前的state计算下一个state,因为当真正执行状态修改时,依赖的this.state并不能保证是最新的state,因为react本身会把多次state合并成一次,这时this.state还是几次state修改前的state,同样也不能依赖当前的props计算下一个状态,因为props的更新也是异步。列对于电商类的应用中,在购物车里,点击一次购买按钮,购买数量会加1,如果连续点击两次,会加2,而在react合并修改为一次的情况下,相当与执行了如下代码:

1

2

3

4

5

Object.assign(

previousState,

{quantity:this.state.quantity+1},

{quantity:this.state.quantity+1},

)

于是后面覆盖前面的操作,最终购买数量只加1,此时可以使用另一个函数作为参数的setState,这个函数有两个参数,第一个参数是当前的最新状态(本次组件状态更新后的状态)的前一个状态preState(本次组件状态修改前的状态),第二个参数是当前最新的props。示列如下:

1

2

3

4

//正确

this.setState((preState,props)=>({

counter:preState.quantity+1

}))

3、state的更新时一个合并的过程

阅读剩余部分

相关阅读 >>

uniapp和React的区别

React中qs是什么

React遵循的原则是什么

React中页面如何传值

React 生命周期函数有哪些

开发React用什么工具?

React中fragment是什么?

React开发框架有哪些?

React中如何优雅的使用svg

React封装自定义组件的正确步骤

更多相关阅读请进入《React》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...