


下載本文檔
版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
第重置Redux的狀態(tài)數(shù)據(jù)的方法實(shí)現(xiàn)
在Redux使用過(guò)程中,通常需要重置store的狀態(tài),比如應(yīng)用初始化的時(shí)候、用戶退出登錄的時(shí)候,這樣能夠避免數(shù)據(jù)殘留,避免UI顯示了上一個(gè)用戶的數(shù)據(jù),容易造成用戶數(shù)據(jù)泄露。
最簡(jiǎn)單的實(shí)現(xiàn)方法就是為每個(gè)獨(dú)立的store添加RESET_APP的action,每次需要reset的時(shí)候,dispatch這個(gè)action即可,如下代碼
constusersDefaultState=[];
constusers=(state=usersDefaultState,{type,payload})={
switch(type){
caseADD_USER:
return[...state,payload];
default:
returnstate;
添加resetaction后:
constusersDefaultState=[]
constusers=(state=usersDefaultState,{type,payload})={
switch(type){
caseRESET_APP:
returnusersDefaultState;
caseADD_USER:
return[...state,payload];
default:
returnstate;
這樣雖然簡(jiǎn)單,但是當(dāng)獨(dú)立的store較多時(shí),需要添加很多action,而且需要很多個(gè)dispatch語(yǔ)句去觸發(fā),比如:
dispatch({type:RESET_USER});
dispatch({type:RESET_ARTICLE});
dispatch({type:RESET_COMMENT});
當(dāng)然你可以封裝一下代碼,讓一個(gè)RESET_DATA的action去觸發(fā)多個(gè)reset的action,避免業(yè)務(wù)代碼看上去太亂。
不過(guò)本文介紹一種更優(yōu)雅的實(shí)現(xiàn),需要用到一個(gè)小技巧,看下面代碼:
constusersDefaultState=[]
constusers=(state=usersDefaultState,{type,payload})={...}
當(dāng)函數(shù)參數(shù)state為undefined時(shí),state就會(huì)去usersDefaultState這個(gè)默認(rèn)值,利用這個(gè)技巧,我們可以在rootReducers中檢測(cè)RESET_DATAaction,直接賦值undefined就完成了所有store的數(shù)據(jù)重置。實(shí)現(xiàn)代碼如下:
我們通常這樣導(dǎo)出所有的reducers
//reducers.js
constro
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年市政工程考試知識(shí)點(diǎn)剖析試題及答案
- 建筑泥工勞務(wù)分包合同
- 農(nóng)村生物技術(shù)應(yīng)用研究開(kāi)發(fā)合同
- 員工關(guān)系在公共關(guān)系中的角色試題及答案
- 掌握中級(jí)經(jīng)濟(jì)師考試復(fù)習(xí)的主動(dòng)權(quán)與試題及答案
- 行政管理??乒碴P(guān)系學(xué)全面試題及答案
- 維護(hù)技術(shù)基礎(chǔ)考試試題及答案
- 市政工程考試準(zhǔn)備全面試題及答案
- 精誠(chéng)團(tuán)結(jié)共繪明天計(jì)劃
- 變速器設(shè)計(jì)畢業(yè)設(shè)計(jì)答辯
- 2025年江蘇省泰州市國(guó)有企業(yè)招聘筆試參考題庫(kù)含答案解析
- 小程序開(kāi)發(fā)合同范本3篇
- 人工智能導(dǎo)論知到智慧樹(shù)章節(jié)測(cè)試課后答案2024年秋天津大學(xué)
- 食品安全知識(shí)8
- 藥品經(jīng)營(yíng)許可證換證申請(qǐng)表
- 電氣識(shí)圖全套試題及參考答案
- 《三只松鼠公司基于近三年數(shù)據(jù)的財(cái)務(wù)探析(4200字論文)》
- 《可復(fù)制的領(lǐng)導(dǎo)力》讀書分享
- 山東師范大學(xué)馬克思主義基本原理期末復(fù)習(xí)題
- GB/T 25085.2-2024道路車輛汽車電纜第2部分:試驗(yàn)方法
- 骨科一病一品
評(píng)論
0/150
提交評(píng)論