首頁 > web前端 > js教程 > react的setSate的非同步問題的分析

react的setSate的非同步問題的分析

不言
發布: 2019-03-23 09:55:54
轉載
2102 人瀏覽過

這篇文章帶給大家的內容是關於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影片教學專欄!

#

以上是react的setSate的非同步問題的分析的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:segmentfault.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板