⊗jsrxPmATER 48 of 57 menu

Redux တွင် အပိုပြုပြင်သူများ

ကျွန်ုပ်တို့ၑ ထုတ်ကုန်များ အက်ပ်ကို ဖွင့်ကြည့်ပြီး ၄င်း၏အတွင်း၌ ဖိုင်အမည် productsSlice.js ကို ရှာကြည့်ပါ။ သင် သတိပြုမိပြီးဖြစ်မည်ထင်သည်၊ thunk fetchProducts ကို သီးခြားလုပ်ဆောင်ချက် တစ်ခုအနေဖြင့် ကျွန်ုပ်တို့ ဖန်တီးခဲ့သည်မဟုတ်လား။ createSlice သည် thunks များကို သတ်မှတ်ခြင်းအား မပံ့ပိုးသောကြောင့် ကျွန်ုပ်တို့ ထိုသို့ ပြုလုပ်ခဲ့ခြင်း ဖြစ်သည်။ ဤအခြေအနေတွင် products slice ၏ reducer အား slice products ၏ အပြင်ဘက်တွင် သတ်မှတ်ထားသော action များကို တုံ့ပြန်ရန် မည်သို့ အင်အားဖြည့်ပေးမည်နည်း။ ကျွန်ုပ်တို့အတွက် thunk fetchProducts မှ ပေးပို့သော action များကို ကိုင်တွယ်ဖြေရှင်းရန် လိုအပ်နေပါသည်။

ထိုကဲ့သို့သော အခြေအနေများအတွက် createSlice တွင် extraReducers ဟူသော ဂုဏ်သတ္တိ တစ်ခုရှိပြီး၊ ၄င်းသည် လက်ရှိ slice တွင် မဟုတ်ဘဲ အခြားနေရာများတွင် သတ်မှတ်ထားသော action များကို ကိုင်တွယ်ဖြေရှင်းမည့် အပိုပြုပြင်သူများ (extra reducers) ထည့်သွင်းခွင့်ပေးသည်။

ယခု createSlice လုပ်ဆောင်ချက်၏ ကိုယ်ထည်အတွင်း၌ reducer အားလုံးပါဝင်သည့် reducers ဂုဏ်သတ္တိ ပြီးနောက်၊ အခြား နည်းလမ်းတစ်ခုဖြစ်သော extraReducers ကို ထပ်မံပေါင်းထည့်ကြပါစို့။

extraReducers() {},

ဤနည်းလမ်းသို့ ကျွန်ုပ်တို့သည် builder ဟူသော အရာဝတ္ထု (object) တစ်ခုကို ပေးပို့ရမည်။ ၎င်း builder တွင် အပိုပြုပြင်သူများ (extra reducers) ထည့်သွင်းရန် အသုံးပြုနိုင်သော နည်းလမ်းများ ပါဝင်သည်။

extraReducers(builder) {},

ကျွန်ုပ်တို့သည် builder ၏ နည်းလမ်းများထဲမှ တစ်ခုဖြစ်သော addCase ကို အသုံးပြုမည်။ ၎င်းသည် ပထမအကြိမ်သတ်မှတ်ချက် (action creator) ကို လက်ခံပြီး၊ ဒုတိယသတ်မှတ်ချက်အနေဖြင့် reducer ကို လက်ခံသည်။ fetchProducts မှ တောင်းဆိုချက် (request) ပြုလုပ်သည့်အခါ ပေးပို့သော action များထဲမှ တစ်ခုမှာ fetchProducts.pending ဖြစ်ပြီး၊ ၄င်းက တောင်းဆိုချက် စတင်ပို့လိုက်ပြီဟု ဖော်ပြသည်။ ဤအခြေအနေတွင် အဆင့်အား (status) 'in progress' သို့ ပြောင်းလဲကြပါစို့ (ယခင်က ၎င်းသည် 'idle' ဖြစ်ခဲ့သည်)။

extraReducers(builder) { builder.addCase(fetchProducts.pending, (state) => { state.status = 'in progress' }) },

ယခု တောင်းဆိုချက် အောင်မြင်စွာ ပြီးမြောက်သည့်အခါ ပေးပို့မည့် action ကို ကိုင်တွယ်ဖြေရှင်းကြပါစို့။ ဤနေရာတွင် ကျွန်ုပ်တို့သည် state အတွင်းရှိ အဆင့်ကို (status) 'success' သို့သာ ပြောင်းလဲရုံမက၊ action ၏ payload ထဲမှ ထုတ်ကုန်များအား products slice ထဲသို့ ယူဆောင်သွားမည်။ ထုတ်ကုန်အားလုံးကို စုစည်းရန် concat နည်းလမ်းကို လိုအပ်ပါမည်။

extraReducers(builder) { builder .addCase(fetchProducts.pending, (state) => { state.status = 'in progress' }) .addCase(fetchProducts.fulfilled, (state, action) => { state.status = 'success' state.products = state.products.concat(action.payload) }) },

တောင်းဆိုချက် မအောင်မြင်ပါက ကျွန်ုပ်တို့သည် အဆင့်ကို (status) 'fail' သို့ ပြောင်းလဲပြီး state ထဲတွင် အမှားအယွင်းအကြောင်း မက်ဆေ့ချ်ကို ရေးမှတ်ထားမည်။

.addCase(fetchProducts.rejected, (state, action) => { state.status = 'fail' state.error = action.error.message })

အကယ်၍ ကျွန်ုပ်တို့ အက်ပ်ကို ယခု အသက်သွင်းပြီး မီနူးထဲတွင် 'Products' ကို နှိပ်ကြည့်ပါက (ဆာဗာပေါ်တွင် ကျွန်ုပ်တို့ သတ်မှတ်ထားသော နှောင့်နှေးမှုကို သတိရပါ။) စက္ကန့်အနည်းငယ်အကြာတွင် ထုတ်ကုန်များစာရင်းပါ စာရင်းကို မြင်တွေ့ရမည်။

ထိုနည်းတူစွာပင် Redux DevTools တွင်လည်း အပြောင်းအလဲများကို မြင်တွေ့ရမည်။ ယခု ကျွန်ုပ်တို့၏ ထုတ်ကုန်များသည် state ထဲတွင်လည်း ပေါ်လာမည် (အကယ်၍ သင်သည် products/fetchProducts/fulfilled action အပေါ် နှိပ်မိပါက 'State' tab ကို ကြည့်ပါ။) အဲဒီမှာပင် အသစ်ဖြစ်သော အဆင့် 'success' ကိုလည်း မြင်ရမည်။ ယခု products/fetchProducts/pending action အပေါ် နှိပ်ကြည့်ပြီး 'State' tab သည် ယခုအခါ မည်သို့ကွဲပြားသွားသည်ကို ကြည့်ပါ။

သင့်အနေဖြင့် ကြုံတွေ့နိုင်သော တစ်ခုတည်းသော မသာယာမှုမှာ (ကျွန်ုပ် ယခင်သင်ခန်းစာတွင် ဤအကြောင်း ပြောခဲ့သည်။) ဒေတာတောင်းဆိုချက်များ ထပ်နေခြင်းပင် ဖြစ်သည်။ ထို့ကြောင့် ကျွန်ုပ်တို့၏ စာရင်းတွင် 8 မဟုတ်ဘဲ 16 ထုတ်ကုန်များနှင့် ဖွံ့ဖြိုးသူ console တွင် အရေးကြီးသော သတိပေးချက်များ ရရှိနိုင်သည်။ ဤပြဿနာကို နောက်လာမည့် သင်ခန်းစာတွင် အတူတကွ ဖြေရှင်းကြပါစို့။

သင်၏ ကျောင်းသားများ အက်ပ်ကို ဖွင့်ပါ။ ၄င်း၏အတွင်း၌ ဖိုင် studentsSlice.js ကို ဖွင့်ပါ။ createSlice လုပ်ဆောင်ချက်၏ ကိုယ်ထည်အတွင်း၌ reducers ဂုဏ်သတ္တိ ပြီးနောက် extraReducers ဂုဏ်သတ္တိကို ပေါင်းထည့်ပါ။ extraReducers နည်းလမ်းသို့ builder ကို ပေးပို့ပါ။

builder.addCase နည်းလမ်းကို အသုံးပြု၍ ဒေတာတောင်းဆိုသည့်အခါ fetchStudents မှ ပေးပို့သော action များ pending, fulfilled နှင့် rejected တို့အတွက် ကိုင်တွယ်ဖြေရှင်းမှုများကို သင်ခန်းစာတွင် ပြသထားသည့်အတိုင်း ထည့်သွင်းပါ။

မြန်မာ
AfrikaansAzərbaycanБългарскиবাংলাБеларускаяČeštinaDanskDeutschΕλληνικάEnglishEspañolEestiSuomiFrançaisहिन्दीMagyarՀայերենIndonesiaItaliano日本語ქართულიҚазақ한국어КыргызчаLietuviųLatviešuМакедонскиMelayuNederlandsNorskPolskiPortuguêsRomânăРусскийසිංහලSlovenčinaSlovenščinaShqipСрпскиSrpskiSvenskaKiswahiliТоҷикӣไทยTürkmenTürkçeЎзбекOʻzbekTiếng Việt
ဝက်ဘ်ဆိုက် လုပ်ဆောင်ခြင်း၊ ဆန်းစစ်လေ့လာခြင်းနှင့် ပုဂ္ဂလိကပြုပြင်ခြင်းအတွက် ကျွန်ုပ်တို့သည် cookie များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်