亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

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

昌邑市| 宜章县| 重庆市| 江城| 秦皇岛市| 宁城县| 台东县| 盐源县| 蓬莱市| 玉田县| 花垣县| 阿拉善右旗| 囊谦县| 郓城县| 吴旗县| 丹阳市| 鱼台县| 水富县| 元氏县| 彰武县| 温州市| 临沭县| 桃江县| 沂南县| 中宁县| 大宁县| 克什克腾旗| 镇康县| 潜江市| 鲁甸县| 厦门市| 阳泉市| 白水县| 新泰市| 三江| 嘉祥县| 江都市| 清水县| 德安县| 宜兰市| 阳新县|