中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

react中setState工作機制的示例分析

發布時間:2021-08-19 11:42:17 來源:億速云 閱讀:121 作者:小新 欄目:web開發

小編給大家分享一下react中setState工作機制的示例分析,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

react 是單向數據流,若想要改變已有組件的外觀,我們只能通過更改組件的 props 或者更新組件的 state。在 react 項目的代碼中我們操作最多的就是 this.setState 方法。下面對 setState 方法進行詳細的說明。

<!--more -->

setState要點:react 框架為了提高性能,會對 state 的更新進行收集、合并、再進行一次批量的狀態更新。這種機制常常導致一些意想不到的情況。

setState 有兩種調用形式:

向 setState 傳遞對象
setState()并不會立即觸發 state 的更新。

//this.state.demo = 1;
handleClick = () => {
  this.setState({demo: 2});
  console.log(this.state.demo);// 1
}

1、?注意:在 addEventListener、setTimeout、ajax 回調中 this.setState 是立即觸發的。

2、setState 會合并更新,可能會造成狀態更新的丟失

handleClick = () => {
  this.setState({demo: this.state.demo + 1});
  this.setState({demo: this.state.demo + 1});
}
//click 之后 demo 為2而不是3

綜上:在同一代碼塊中不要多次調用 this.setState 方法

react 的 setState 還提供了另一種調用形式: this.setState(callbackFunc)

this.setState((previousState, currentProps) => {
  return { ...previousState, foo: currentProps.bar };
});

該語法和直接為 setState 傳遞對象不同,不會合并更新。

// demo + 1
handleSyncStateChange = () => {
  this.setState({
    demo: this.state.demo + 1
  });
  this.setState({
    demo: this.state.demo + 1
  });

}
// demo + 2
handleAsyncStateChange = () => {
  this.setState((preState, preProps) => {
    return {
      demo: preState.demo + 1
    }
  });
  this.setState((preState, preProps) => {
    return {
      demo: preState.demo + 1
    }
  });
}

refs

Async Nature Of setState

以上是“react中setState工作機制的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

巩留县| 文昌市| 资讯| 阿坝| 天津市| 措美县| 百色市| 永泰县| 固镇县| 岚皋县| 新乡市| 图片| 宝兴县| 依安县| 孙吴县| 富宁县| 含山县| 桑日县| 河北省| 金溪县| 和平县| 娱乐| 任丘市| 瑞昌市| 唐河县| 措美县| 镇安县| 精河县| 海晏县| 台北县| 渭南市| 南江县| 登封市| 伊春市| 海原县| 福贡县| 新泰市| 裕民县| 镇平县| 平湖市| 定远县|