最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

react的setSate的异步问题的分析

来源:懂视网 责编:小采 时间:2020-11-27 19:27:00
文档

react的setSate的异步问题的分析

react的setSate的异步问题的分析:本篇文章给大家带来的内容是关于react的setSate的异步问题的分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。在我们阅读文档的时候,大多都说react的setState是异步的,可是它真的是异步的吗?如果是,那我们还可以猜想:那可以不可以
推荐度:
导读react的setSate的异步问题的分析:本篇文章给大家带来的内容是关于react的setSate的异步问题的分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。在我们阅读文档的时候,大多都说react的setState是异步的,可是它真的是异步的吗?如果是,那我们还可以猜想:那可以不可以

本篇文章给大家带来的内容是关于react的setSate的异步问题的分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。

在我们阅读文档的时候,大多都说react的setState是异步的,可是它真的是异步的吗?如果是,那我们还可以猜想:那可以不可以同步?那什么时候需要异步,什么时候需要同步呢?

我们先来看下react的官方对setSate的说明:

将setState()认为是一次请求而不是一次立即执行更新组件的命令。为了更为可观的性能,React可能会推迟它,稍后会一次性更新这些组件。React不会保证在setState之后,能够立刻拿到改变的结果。

一个很经典的例子:

// 初始state.count 当前为 0
componentDidMount(){
 this.setState({count: state.count + 1});
 console.log(this.state.count)
}

如果你熟悉react,你一定知道最后的输出结果是0,而不是1。

我们再来看一个例子

class Demo extends Component {
 constructor(props) {
 super(props);
 this.state = { number: 0 };
 }
 render() {
 return <button ref="button" onClick={this.onClick.bind(this)}>点我</button>;
 }
 componentDidMount() {
 //手动绑定mousedown事件
 this.refs.button.addEventListener(
 "mousedown",
 this.onClick.bind(this)
 );
 
 //setTimeOut
 setTimeout(this.onClick.bind(this), 1000);
 }
 onClick(event) {
 if (event) {
 console.log(event.type);
 } else {
 console.log("timeout");
 }
 console.log("prev state:", this.state.number);
 this.setState({
 number: this.state.number + 1
 });
 console.log("next state:", this.state.number);
 }
}
export {Demo};

在这个组件中采用3中方法更新state

 1.在p节点中绑定onClick事件
 2.在componentDidMount中手动绑定mousedown事件
 3.在componentDidMount中使用setTimeout调用onClick

在点击组件后,你可以猜到结果吗?输出结果是:

timeout
prev state: 0
next state: 1
mousedown
prev state: 1
next state: 2
click
prev state: 2
next state: 2

结果似乎有点出人意料,三种方式只有在p上绑定的onClick事件输出了可以证明setState是异步的结果,另外两种方式显示setState似乎是同步的。

总结:
1.在组件生命周期中或者react事件绑定中,setState是通过异步更新的。
2.在延时的回调或者原生事件绑定的回调中调用setState不一定是异步的。

这个结果并不说明setState异步执行的说法是错误的,更加准确的说法应该是setState不能保证同步执行。

本篇文章到这里就已经全部结束了,更多其他精彩内容可以关注PHP中文网的JavaScript视频教程栏目!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

react的setSate的异步问题的分析

react的setSate的异步问题的分析:本篇文章给大家带来的内容是关于react的setSate的异步问题的分析,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助。在我们阅读文档的时候,大多都说react的setState是异步的,可是它真的是异步的吗?如果是,那我们还可以猜想:那可以不可以
推荐度:
标签: 问题 异步 React
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top