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

溫馨提示×

溫馨提示×

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

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

React中setState如何使用與如何同步異步

發布時間:2021-03-15 11:08:53 來源:億速云 閱讀:402 作者:TREX 欄目:開發技術

這篇文章主要介紹“React中setState如何使用與如何同步異步”,在日常操作中,相信很多人在React中setState如何使用與如何同步異步問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”React中setState如何使用與如何同步異步”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

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

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

定義初始狀態

state = { count: 0 },

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

(1)傳遞對象

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

(2)傳遞函數

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

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

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

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

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

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

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

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

☆☆☆☆☆ 是異步的

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

(2) 為什么是異步?

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

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

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

② 在componentDidUpdate中獲取

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

☆☆☆☆☆ 是同步的

(1) 即我們通過this.setState修改狀態之后,在它的下一行輸出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)
}

到此,關于“React中setState如何使用與如何同步異步”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!

向AI問一下細節

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

AI

宣汉县| 额敏县| 宣城市| 隆昌县| 巩义市| 光泽县| 娱乐| 枣阳市| 锦州市| 家居| 高邮市| 甘谷县| 大丰市| 湘潭县| 塔河县| 廉江市| 南城县| 昭觉县| 开江县| 柯坪县| 邯郸市| 凤城市| 巴林右旗| 九龙坡区| 巴楚县| 小金县| 凤冈县| 施甸县| 内乡县| 新巴尔虎右旗| 新田县| 渑池县| 宣威市| 钦州市| 博兴县| 中西区| 新兴县| 育儿| 漠河县| 合阳县| 于都县|