Hi everyone! I'm the author of code.mu :)
I'd love to chat with my non-Russian audience. I'm looking for your feedback on the site and the translation quality. Let's chat:)
⊗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 များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်