您好,登錄后才能下訂單哦!
這篇文章主要介紹“React中setState如何使用與如何同步異步”,在日常操作中,相信很多人在React中setState如何使用與如何同步異步問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”React中setState如何使用與如何同步異步”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!
在react中,修改狀態如果直接使用this.state,不會引起組件的重新渲染,需要通過 this.setState來對組件的屬性進行修改。
定義初始狀態
state = { count: 0 },
如果此時有一個按鈕,點擊按鈕讓計數加1,我們可以有兩種寫法
(1)傳遞對象
this.setState({ count: this.state.count + 1})
(2)傳遞函數
this.setState((state, props) => ({ count: count + 1}))
如果變更的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的值就已經被修改了
☆☆☆☆☆ 是異步的
(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如何使用與如何同步異步”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續學習更多相關知識,請繼續關注億速云網站,小編會繼續努力為大家帶來更多實用的文章!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。