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

溫馨提示×

溫馨提示×

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

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

react中獲取state的方法

發布時間:2021-02-03 09:42:03 來源:億速云 閱讀:448 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關react中獲取state的方法,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

react中獲取state的方法:首先打開相應的react代碼文件;然后在react中可以通過“this.state.{屬性}”的方式直接獲取state即可。

react中獲取state的方法

react中怎么獲取state?

在react中可以通過this.state.{屬性}的方式直接獲取state,但是當我們修改state的時候,往往有許多的坑需要注意。

以下為三種常見的陷阱:

1、不能直接修改state。

組件修改state,并不會重新觸發render。列如:

//錯誤
this.state.title='React';
正確修改方式是使用setState();
//正確
this.setState({title:'React'});

2、state的更新時異步的

調用setState時,組件state并不會立即改變,只是把要修改的狀態放入事件隊列當中,而react會優化真正的執行時機,并且處于本身的性能原因,可能會將多次setState的狀態修改合并成一次狀態修改。因此不要依靠當前的state計算下一個state,因為當真正執行狀態修改時,依賴的this.state并不能保證是最新的state,因為react本身會把多次state合并成一次,這時this.state還是幾次state修改前的state,同樣也不能依賴當前的props計算下一個狀態,因為props的更新也是異步。列對于電商類的應用中,在購物車里,點擊一次購買按鈕,購買數量會加1,如果連續點擊兩次,會加2,而在react合并修改為一次的情況下,相當與執行了如下代碼:

Object.assign(
previousState,
{quantity:this.state.quantity+1},
{quantity:this.state.quantity+1},
)

于是后面覆蓋前面的操作,最終購買數量只加1,此時可以使用另一個函數作為參數的setState,這個函數有兩個參數,第一個參數是當前的最新狀態(本次組件狀態更新后的狀態)的前一個狀態preState(本次組件狀態修改前的狀態),第二個參數是當前最新的props。示列如下:

//正確
this.setState((preState,props)=>({
counter:preState.quantity+1
}))

3、state的更新時一個合并的過程

當調用ssetState()修改組件的狀態時,只需要傳入發生改變的state,而不是完整的state,因為組件state的更新時一個合并的過程,列如,一個組件的狀態為:

this.state({
title:'React',
content:'React is an wondeful JS library'
})

當只需要修改title時,只需要將修改的title傳給setState即可:

this.setState({title:'ReactJs'});

react會合并最新的title到原來的狀態,同時保留原來狀態的content,最終合并state為:

this.state({
title:'ReactJs,
content:''React is an wondeful Js library
}

關于“react中獲取state的方法”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

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

AI

高密市| 桑日县| 扎鲁特旗| 曲阜市| 江口县| 富宁县| 昭通市| 遂溪县| 承德县| 工布江达县| 屯昌县| 肃宁县| 洞头县| 武宁县| 华蓥市| 剑河县| 子长县| 青铜峡市| 吉木乃县| 喀喇| 鲜城| 磐石市| 明水县| 扎赉特旗| 正镶白旗| 黔东| 旬阳县| 遂溪县| 华安县| 青冈县| 威信县| 荣成市| 环江| 临海市| 吴旗县| 平阴县| 霍城县| 鹰潭市| 吉隆县| 浮山县| 清流县|