⊗jsrxPmATGS 51 of 57 menu

Redux အတွင်း ရောင်းချသူများ၏ အချက်အလက်များ ရယူခြင်း

ကျွန်ုပ်တို့၏ ထုတ်ကုန်များပါဝင်သည့် application ကို စတင်လိုက်ကြပါစို့။ ထုတ်ကုန်ကတ်များတွင် ရောင်းချသူများကို မပြသထားသည်ကို ကျွန်ုပ်တို့ တွေ့မြင်ရပါသည်။ ယင်းအချက်အလက်များကို server မှ ရယူ၍ ဖော်ပြကြပါစို့။ ၎င်းအတွက် ကျွန်ုပ်တို့သည် ရင်းနှီးပြီးသော လုပ်ဆောင်ချက်အစဉ်ကို အကောင်အထည်ဖော်ရပါမည်။

အစပိုင်းအနေဖြင့် server.js ဖိုင်ကို ဖွင့်ပါ။ handlers array ကို ရှာပြီး ၎င်းအတွင်းသို့ GET request တစ်ခုအတွက် ထပ်မံအလုပ်လုပ်ပေးခြင်း (ထုတ်ကုန်များအတွက် GET အလုပ်လုပ်ပေးပြီးနောက်) ထည့်ပါ။ သင်မြင်တွေ့ရသည့်အတိုင်း ၎င်းသည် လက်တွေ့အားဖြင့် အတူတူနီးပါးဖြစ်ပါသည်။

http.get('/fakeServer/sellers', async () => { await delay(ARTIFICIAL_DELAY_MS) return HttpResponse.json(db.seller.getAll()) }),

Server ပေါ်ရှိ request ကို ကျွန်ုပ်တို့ အလုပ်လုပ်ပေးလိုက်ပါပြီ။ နောက်အဆင့်အနေဖြင့် sellersSlice.js ဖိုင်တွင် server မှ အချက်အလက်များရယူရန် thunk ကို ရေးသားရပါမည်။ ၎င်းအတွက် client နှင့် createAsyncThunk တို့ကို ထည့်သွင်းရပါမည်။

import { createSlice, createAsyncThunk } from '@reduxjs/toolkit' import { client } from '../../api/client'

ယခု ကျွန်ုပ်တို့သည် ရောင်းချသူများကို server မှ ရယူတော့မည်ဖြစ်ရာ၊ ၎င်းတို့ကို initialState မှ ဖယ်ရှား၍ ကွင်းလပ်များသာ ချန်ထားပါမည်။

const initialState = []

ထို့နောက် sellersSlice ဖန်ရှင်မတိုင်မီ ကျွန်ုပ်တို့၏ thunk fetchSellers ကို ဖန်တီးပါမည်။ Server ပေါ်တွင် ကျွန်ုပ်တို့ သတ်မှတ်ထားသည့် path ကို client သို့ ပေးပို့ပါမည်။

export const fetchSellers = createAsyncThunk( 'sellers/fetchSellers', async () => { const response = await client.get('/fakeServer/sellers') return response.data } )

sellersSlice အတွက် extra reducer တစ်ခု ဖန်တီးရန်သာ ကျန်တော့ပါသည်။ ဤနေရာတွင် request အောင်မြင်စွာ အလုပ်လုပ်ပေးခြင်းကိုသာ ကန့်သတ်ထားပါမည်။ fetchSellers မှ ထုတ်လုပ်သော action အားလုံးသည် fetchProducts ၏ action များနှင့် အတူတူပင်ဖြစ်ပါမည်။

const sellersSlice = createSlice({ name: 'sellers', initialState, reducers: {}, extraReducers(builder) { builder.addCase(fetchSellers.fulfilled, (state, action) => { return action.payload }) }, })

အရင်အကြိမ်က ထုတ်ကုန်များရယူချိန်တွင် လက်ရှိ state တန်ဖိုးကို ပြောင်းလဲခဲ့ကြောင်း သတိရပါ။ ဤနေရာတွင် ကျွန်ုပ်တို့သည် အနည်းငယ်ကွဲပြားသည့် နည်းလမ်းကို အသုံးပြု၍ အသစ်တန်ဖိုးတစ်ခုသာ ပြန်ပေးခဲ့သည်၊ createSlice အတွင်းတွင်လည်း ဤသို့ပြုလုပ်နိုင်သည်။ ဤသို့ဖြင့် ရည်မှန်းချက်နှစ်ခုကို အောင်မြင်စေပါသည်။ ပထမအချက်အနေဖြင့် ကျွန်ုပ်တို့သည် အချက်အလက်များကို ရရှိခဲ့ပြီး၊ ဒုတိယအချက်အနေဖြင့် ရောင်းချသူစာရင်းထဲတွင် အခြားအရာများ ထပ်မံပေါ်ထွက်လာမည်မဟုတ်ကြောင်း အာမခံချက်ရရှိပါသည်၊ အဘယ့်ကြောင့်ဆိုသော် ကျွန်ုပ်တို့သည် slice တစ်ခုလုံးကို action.payload တန်ဖိုးဖြင့် အစားထိုးရေးသားလိုက်သောကြောင့်ဖြစ်သည်။

သင့်၏ ကျောင်းသားများနှင့် application ကို ဖွင့်ပါ။ ၎င်းအတွင်းရှိ server.js ဖိုင်ကို ဖွင့်၍ handlers array အတွင်းသို့ သင်ကြားပေးသူများအတွက် GET request အလုပ်လုပ်ပေးခြင်းတစ်ခုကို ထပ်ထည့်ပါ။

ယခု teachersSlice.js ဖိုင်ကို ဖွင့်ပါ။ initialState ကို သင်ခန်းစာတွင် ပြထားသည့်အတိုင်း ကွင်းလပ်တစ်ခု ဖြစ်အောင်လုပ်ပါ။ studentsSlice ဖန်ရှင်မတိုင်မီ fetchTeachers thunk ကို ရေးသားပါ။

createSlice ဖန်ရှင်အတွင်း extra reducer ကို ဖြည့်စွက်ရေးသားပါ၊ request အောင်မြင်စွာ အလုပ်လုပ်ပေးခြင်းကိုသာ ကန့်သတ်ပါ။

မြန်မာ
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 များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်