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?實踐示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-11-11react-router-dom入門使用教程(路由的模糊匹配與嚴格匹配)
這篇文章主要介紹了react-router-dom入門使用教程,主要介紹路由的模糊匹配與嚴格匹配,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08React如何使用create-react-app創(chuàng)建react項目
這篇文章主要介紹了React如何使用create-react-app創(chuàng)建react項目問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-03-03詳解一個基于react+webpack的多頁面應(yīng)用配置
這篇文章主要介紹了詳解一個基于react+webpack的多頁面應(yīng)用配置,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01React路由渲染方式與withRouter高階組件及自定義導(dǎo)航組件應(yīng)用詳細介紹
這篇文章主要介紹了React路由三種渲染方式、withRouter高階組件、自定義導(dǎo)航組件,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)吧2022-09-09Shopee在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