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

react純函數(shù)組件setState更新頁面不刷新的解決

 更新時間:2021年06月29日 09:33:40   作者:蒙悅納  
在開發(fā)過程中,經(jīng)常遇到組件數(shù)據(jù)無法更新,本文主要介紹了react純函數(shù)組件setState更新頁面不刷新的解決,感興趣的可以了解一下

問題描述:

const [textList, setTextList] = useState(原數(shù)組);
setTextList(新數(shù)組);


當(dāng)修改原數(shù)組時,如果原數(shù)組是個深層數(shù)組(不只一層),使用setTextList修改時,不會觸發(fā)頁面刷新

原因分析:

這個涉及到可變對象he不可變對象的知識,在vue和react中,如果更新可變對象時,可能會引起視圖更新,這是因為,vue和react默認都是淺監(jiān)聽,只會監(jiān)聽數(shù)據(jù)的第一層,內(nèi)層數(shù)據(jù)發(fā)生改變,并不會監(jiān)聽到。

解決方案:

這里我的解決方案是,先將原數(shù)組深拷貝,賦值給新數(shù)組,再修改新數(shù)組,將修改后的新數(shù)組傳遞進去,這樣就會引起視圖更新。

var lists = textList.concat();
lists.splice(index, 1);
setTextList(lists);

補:react中,hooks鉤子時useState更新不渲染組件的問題

當(dāng)使用react,寫如圖組件時,發(fā)現(xiàn)一個很關(guān)鍵的問題,當(dāng)選擇用class寫的時候,很容易通過組件更新渲染。
當(dāng)我決定用函數(shù)式組件hooks來重構(gòu)我的組件的時候,發(fā)現(xiàn)了一個很難搞的問題,當(dāng)我通過onChange去改變父組件value的時候,value的值改了,竟然沒有重新渲染組件????
一臉懵逼的我,于是試圖將class組件時先將value設(shè)為空再賦值-----失敗了
于是試圖通過鉤子的生命周期看了一遍。。。。------失敗了
還是百度吧------發(fā)現(xiàn)了同樣的問題。。。發(fā)現(xiàn)用只要再后面加slice()
于是本著先解決問題的態(tài)度,將圖中紅圈位置改為了onChange(value.slice())
-----于是,解決了這個神奇的問題。

現(xiàn)在問題解決了,回過頭來看看到底怎么回事。。。
查看文檔發(fā)現(xiàn)一句話useState里數(shù)據(jù)務(wù)必為immutable (不可賦值的對象)
也就是ass component的state也提倡使用immutable數(shù)據(jù),但不是強制的,因為只要調(diào)用了setState就會觸發(fā)更新。所以再class組件中沒有出現(xiàn)這種問題,或者通過改變?yōu)榭赵儋x值是可以觸發(fā)更新的。
但是再使用useState時,如果在更新函數(shù)里傳入同一個對象時將無法觸發(fā)更新。
于是解決思路就是通過slice() 返回一個新的對象去賦值是解決問題的關(guān)鍵。。。。

以上就是react純函數(shù)組件setState更新頁面不刷新的解決的詳細內(nèi)容,更多關(guān)于react useState頁面不刷新的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • ReactQuery系列React?Query?實踐示例詳解

    ReactQuery系列React?Query?實踐示例詳解

    這篇文章主要為大家介紹了ReactQuery系列React?Query?實踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11
  • react中(含hooks)同步獲取state值的方式

    react中(含hooks)同步獲取state值的方式

    這篇文章主要介紹了react(含hooks)中同步獲取state值的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-08-08
  • react-router-dom入門使用教程(路由的模糊匹配與嚴格匹配)

    react-router-dom入門使用教程(路由的模糊匹配與嚴格匹配)

    這篇文章主要介紹了react-router-dom入門使用教程,主要介紹路由的模糊匹配與嚴格匹配,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-08-08
  • React如何使用create-react-app創(chuàng)建react項目

    React如何使用create-react-app創(chuàng)建react項目

    這篇文章主要介紹了React如何使用create-react-app創(chuàng)建react項目問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 詳解一個基于react+webpack的多頁面應(yīng)用配置

    詳解一個基于react+webpack的多頁面應(yīng)用配置

    這篇文章主要介紹了詳解一個基于react+webpack的多頁面應(yīng)用配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2019-01-01
  • React路由渲染方式與withRouter高階組件及自定義導(dǎo)航組件應(yīng)用詳細介紹

    React路由渲染方式與withRouter高階組件及自定義導(dǎo)航組件應(yīng)用詳細介紹

    這篇文章主要介紹了React路由三種渲染方式、withRouter高階組件、自定義導(dǎo)航組件,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧
    2022-09-09
  • Shopee在React?Native?架構(gòu)方面的探索及發(fā)展歷程

    Shopee在React?Native?架構(gòu)方面的探索及發(fā)展歷程

    這篇文章主要介紹了Shopee在React?Native?架構(gòu)方面的探索,本文會從發(fā)展歷史、架構(gòu)模型、系統(tǒng)設(shè)計、遷移方案四個方向逐一介紹我們?nèi)绾我徊讲降貪M足多團隊在復(fù)雜業(yè)務(wù)中的開發(fā)需求,需要的朋友可以參考下
    2022-07-07
  • react中hook介紹以及使用教程

    react中hook介紹以及使用教程

    這篇文章主要給大家介紹了關(guān)于react中hook及使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-12-12
  • React和Vue組件更新的實現(xiàn)及區(qū)別

    React和Vue組件更新的實現(xiàn)及區(qū)別

    React 和 Vue 都是當(dāng)今最流行的前端框架,它們都實現(xiàn)了組件化開發(fā)模式,本文將從React和Vue的組件更新原理入手,剖析兩者虛擬DOM difer算法的異同點,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • React Native功能豐富的Toast通知庫

    React Native功能豐富的Toast通知庫

    這篇文章主要為大家介紹了React Native功能豐富的Toast通知庫使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-10-10

最新評論