⊗jsrtPmRtLd 30 of 47 menu

React Router ရှိ လမ်းကြောင်းအတွက် ဒေတာ ဖတ်တဲ့သူ (Data Loader)

ပြီးခဲ့တဲ့သင်ခန်းစာမှာ ကုန်ပစ္စည်းဒေတာတွေကို သိုလှောင်ရာနေရာ (store) ကနေ ထုတ်ယူခဲ့ပါတယ်။ အခု ဒီ ဒေတာတွေကို လမ်းကြောင်းအစိတ်အပိုင်း (route element) ထဲ ထည့်ဖို့လိုပါတယ်။ ဒါအတွက် ဒေတာဖတ်တဲ့သူ (loader) လို့ခေါ်တဲ့ ဖန်ရှင်ကို အသုံးပြုပါတယ်။ အခု ကျွန်တော်တို့ ဒါကို ဖန်တီးကြမယ်။

root.jsx ဖိုင်ကို ဖွင့်ပါ၊ ဒီမှာ getProducts ကို forStorage.js ကနေ import လုပ်တဲ့စာကြောင်း ထည့်ပါမယ် :

import { getProducts } from '../forStorage'

Import စာကြောင်းတွေရဲ့ ချက်ချင်းနောက်မှာနဲ့ Root ဖန်ရှင် Root မစခင် loader လို့ခေါ်တဲ့ ဖန်ရှင်ကိုရေးပါမယ်၊ ဒီဖန်ရှင်က getProducts ကနေတဆင့် သိုလှောင်ရာနေရာ (store) ထဲက ကုန်ပစ္စည်းဒေတာတွေကို ပြန်ပေးပါလိမ့်မယ်။ အနှစ်ချုပ်အားဖြင့် ဒီလိုဖန်ရှင်တွေကို သီးခြားဖိုင်တစ်ခုမှာရေးသင့်ပေမယ့် ကျွန်တော်တို့က အနည်းငယ်ပျင်းရိပါတယ်၊ ဒါကြောင့် သတိပေးချက်ကို ဂရုမပြုပါနဲ့။

export async function loader() { const products = await getProducts(); return { products }; }

အခု ကျွန်တော်တို့ရဲ့ ဒေတာဖတ်သူ (loader) ကို main.jsx ထဲမှာ import လုပ်ကြပါစို့။ ဒီ ဒေတာဖတ်သူဟာ root အတွက်ဖြစ်တာကြောင့် သူ့ကို rootLoader လို့ခေါ်ပါမယ် :

import Root, { loader as rootLoader } from './routes/root';

ပြီးရင် သူ့ကို ကျွန်တော်တို့ရဲ့ လမ်းကြောင်း (route) object ထဲက loader ဆိုတဲ့ property ထဲမှာ ထည့်ပါမယ် :

const router = createBrowserRouter([ { path: '/', element: <Root />, errorElement: <ErrorPage404 />, loader: rootLoader, children: [ { path: 'products/:productId', element: <Product />, }, ], }, ]);

သင့်ရဲ့ ယခင်သင်ခန်းစာတွေရဲ့ တာဝန်တွေမှာ ဖန်တီးခဲ့တဲ့ application ကို ယူပါ။ သင်ခန်းစာရဲ့ ပစ္စည်းတွေကို အသုံးပြုပြီး root.jsx ဖိုင်ထဲမှာ ကျောင်းသားဒေတာတွေကို ဖတ်ဖို့ loader ဖန်ရှင်ကို ရေးပါ၊ ပြီးရင် သူ့ကို main.jsx ထဲက လမ်းကြောင်း object ထဲမှာ ထည့်ပါ။

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