欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React中setState的使用與同步異步的使用

 更新時間:2021年03月15日 09:42:07   作者:一顆冰淇淋  
這篇文章主要介紹了React中setState的使用與同步異步的使用,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

在react中,修改狀態(tài)如果直接使用this.state,不會引起組件的重新渲染,需要通過 this.setState來對組件的屬性進行修改。

1、this.setState的兩種定義方式

定義初始狀態(tài)

state = { count: 0 },

如果此時有一個按鈕,點擊按鈕讓計數(shù)加1,我們可以有兩種寫法

(1)傳遞對象

this.setState({ count: this.state.count + 1})

(2)傳遞函數(shù)

this.setState((state, props) => ({ count: count + 1}))

2、setState的兩種方式有什么不同?

如果變更的state的值需要依賴于上一次的state的值,這種情況就需要用到函數(shù)的形式,比如以下這種情況

addCount(){
  this.setState({ count: this.state.count + 1})
  this.setState({ count: this.state.count + 1})
  this.setState({ count: this.state.count + 1})
}

此時只會執(zhí)行一次+1的操作,因為在React內(nèi)部,會將多次setState合并操作,新的state由 Object.assgin({}, {count: 0},  { count: 1}) 合并所得,以上賦值會執(zhí)行三次,但因為count的值沒有更新,所以最終執(zhí)行的結(jié)果只+1,如果setState的賦值是函數(shù),那情況就不一樣了

addCount(){
  this.setState((state, props) => ({ count: count + 1}))
  this.setState((state, props) => ({ count: count + 1}))
  this.setState((state, props) => ({ count: count + 1}))
}

這樣的操作會得到+3的效果,因為React會進行判斷,如果傳入的是函數(shù),那么將執(zhí)行此函數(shù),此時count的值就已經(jīng)被修改了

3、setState是同步還是異步的?

☆☆☆☆☆ 是異步的

(1) 即我們通過this.setState修改了狀態(tài)之后,在它的下一行輸出state的值并不會得到新的值

(2) 為什么是異步?

有兩個原因,一是提高效率,每次修改state的值都會造成render的重新渲染,將多次修改state的值合并統(tǒng)一更新可以提高性能;二是render的更新會晚一些,如果render中有子組件,子組件的props依賴于父組件的state,props和state就不能保持一致

(3) 如何獲取異步時的state值?
① 在setState的回調(diào)函數(shù)中

this.setState({ 
  count: this.state.count + 1}}, 
  ()=>{ console.log(this.state.count)})

② 在componentDidUpdate中獲取

componentDidUpdate(){
  console.log(this.state.count)
}

☆☆☆☆☆ 是同步的

(1) 即我們通過this.setState修改狀態(tài)之后,在它的下一行輸出state是新的值

(2) 什么場景下是同步的?
① 原生js獲取dom元素,并綁定事件

<button id="addBtn">點我+1</button>
componentDidMount(){
   const addBtn = document.getElementById('addBtn')
   changeBtn.addEventListener('click',()=>{
       this.setState({ count: this.state.count + 1})
       console.log(this.state.message)
   })
}

② 計時器 setTimeout

<button onClick={ e => this.addOne() }>點我+1</button>
addOne(){
setTimeout(()=>{ this.setState({ count: this.state.count + 1 })
 console.log(this.state.count ) },0)
}

到此這篇關(guān)于React中setState的使用與同步異步的使用的文章就介紹到這了,更多相關(guān)React setState同步異步內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 深入淺析react native es6語法

    深入淺析react native es6語法

    這篇文章主要介紹了深入淺析react native es6語法的相關(guān)資料,需要的朋友可以參考下
    2015-12-12
  • 詳解create-react-app 自定義 eslint 配置

    詳解create-react-app 自定義 eslint 配置

    這篇文章主要介紹了詳解create-react-app 自定義 eslint 配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-06-06
  • React-Native實現(xiàn)ListView組件之上拉刷新實例(iOS和Android通用)

    React-Native實現(xiàn)ListView組件之上拉刷新實例(iOS和Android通用)

    本篇文章主要介紹了React-Native實現(xiàn)ListView組件之上拉刷新實例(iOS和Android通用),具有一定的參考價值,有興趣的可以了解一下
    2017-07-07
  • React使用ref方法與場景介紹

    React使用ref方法與場景介紹

    這篇文章主要介紹了React使用ref方法與場景,React支持給任意組件添加特殊屬性。ref屬性接受一個回調(diào)函數(shù),它在組件被加載或卸載時會立即執(zhí)行
    2022-10-10
  • React?classnames原理及測試用例

    React?classnames原理及測試用例

    這篇文章主要為大家介紹了React?classnames原理及測試用例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-12-12
  • React關(guān)于antd table中select的設(shè)值更新問題

    React關(guān)于antd table中select的設(shè)值更新問題

    這篇文章主要介紹了React關(guān)于antd table中select的設(shè)值更新問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • React?forwardRef?用法案例分析

    React?forwardRef?用法案例分析

    這篇文章主要介紹了React forwardRef用法,forwardRef允許你的組件使用ref將一個DOM節(jié)點暴露給父組件,本文結(jié)合案例分析給大家講解的非常詳細,需要的朋友可以參考下
    2023-06-06
  • 詳解使用React進行組件庫開發(fā)

    詳解使用React進行組件庫開發(fā)

    本篇文章主要介紹了詳解使用React進行組件庫開發(fā),小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-02-02
  • react后臺系統(tǒng)最佳實踐示例詳解

    react后臺系統(tǒng)最佳實踐示例詳解

    這篇文章主要為大家介紹了react后臺系統(tǒng)最佳實踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • React實現(xiàn)Excel文件的導出與在線預覽功能

    React實現(xiàn)Excel文件的導出與在線預覽功能

    這篇文章主要為大家詳細介紹了如何利用?React?18?的強大功能,演示如何使用?React?18?編寫?Excel?文件的導出與在線預覽功能,需要的小伙伴可以參考下
    2023-12-12

最新評論