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

溫馨提示×

溫馨提示×

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

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

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

马龙县| 顺平县| 武穴市| 额济纳旗| 如东县| 千阳县| 苍溪县| 正定县| 岳阳市| 肥西县| 邵东县| 吉林省| 棋牌| 临夏市| 梁山县| 富锦市| 诏安县| 古浪县| 顺义区| 北安市| 稷山县| 星子县| 崇左市| 鲁甸县| 陈巴尔虎旗| 阳原县| 南汇区| 咸丰县| 芜湖县| 阿城市| 秦皇岛市| 遵化市| 平阳县| 固阳县| 蓬安县| 郎溪县| 彩票| 仁布县| 太仆寺旗| 陆河县| 若羌县|