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:)
⊗jsrtPmRtDER 38 of 47 menu

React Router တွင် ဒေတာများ တည်းဖြတ်ရန် လမ်းကြောင်း တစ်ခု ဖန်တီးခြင်း

အရင်သင်ခန်းစာမှာ ကျွန်တော်တို့က React component EditProduct သပ်သပ်ရပ်ရပ်ထဲမှာ တည်းဖြတ်ဖို့ ဖောင်တစ်ခု ဖန်တီးခဲ့ပါတယ်။

အခု import လုပ်ပြီးတာနဲ့ EditProduct အလုပ်လုပ်တဲ့ function ရဲ့ အရင်မှာ လမ်းကြောင်းအသစ်အတွက် loader function ကို ရေးလိုက်ရအောင်။ သူက product.jsx ထဲကလိုပဲ ဖြစ်လိမ့်မယ်။ Function ထဲကို URL parameter တွေ ပို့ပေးမယ်၊ ပြီးရင် သူ့ရဲ့ id အလိုက် ထုတ်ကုန်ကို ရယူမယ်။

export async function loader({ params }) { const product = await getProduct(params.productId); return { product }; }

getProduct ကို forStorage.js ကနေ import လုပ်ပါမယ်။

import { getProduct } from '../forStorage';

အခု ကျွန်တော်တို့ရဲ့ main.jsx ကို ဖွင့်ပြီး ကိုယ်တိုင် ဖန်တီးထားတဲ့ component EditProduct နဲ့ loader ကို import လုပ်လိုက်ရအောင်။

import EditProduct, { loader as editProductLoader } from './routes/edit';

ပြီးရင် ထုတ်ကုန်အတွက် လမ်းကြောင်းရဲ့ နောက်ကနေ တည်းဖြတ်ခြင်းအတွက် လမ်းကြောင်း object ကို children array ထဲကို ထည့်လိုက်ပါမယ်။

children: [ { path: 'products/:productId', element: <Product />, loader: productLoader, }, { path: 'products/:productId/edit', element: <EditProduct />, loader: editProductLoader, }, ],

အခု application ကို စတင်လိုက်ပါ၊ ထုတ်ကုန်တစ်ခု ဖန်တီးပါ၊ အဲဒါကို နှိပ်ပါ၊ ပြီးရင် တည်းဖြတ်ရန် ခလုတ်ကို နှိပ်ပါ၊ ကျွန်တော်တို့ရဲ့ ဖောင်လေး ကို မြင်ရပါလိမ့်မယ်။

ကျန်နေသေးတာက ဖောင်ထဲက အကွက်တွေမှာ တည်းဖြတ်ခါနီး လက်ရှိဒေတာတွေ ပါလာအောင် လုပ်ဖို့ပါပဲ။ ဒါအတွက် ကျွန်တော်တို့က edit.jsx ထဲမှာ hook useLoaderData ကို import လုပ်ပါမယ်။

import { Form, useLoaderData } from 'react-router-dom';

ပြီးရင် EditProduct function ထဲမှာ loader ကနေ ဒေတာတွေ ရယူဖို့ သူ့ကို သုံးပါမယ်။ return command ရဲ့ အရင်မှာ သူ့ကို ထည့်လိုက်ပါမယ်။

const { product } = useLoaderData();

အခု input tag တစ်ခုစီမှာ defaultValue attribute ကို သက်ဆိုင်ရာ input တစ်ခုစီအတွက် တန်ဖိုးတွေနဲ့ ထည့်လိုက်ပါမယ်။ ဥပမာ၊ ပထမ input က အခုဆိုရင် ဒီလိုပုံစံ ဖြစ်သွားပါမယ်။

<input placeholder="name" type="text" name="name" defaultValue={product.name} />

ကျန်တဲ့ input နှစ်ခုအတွက် တန်ဖိုးတွေကတော့ အသီးသီး 'product.cost' နဲ့ 'product.amount' ဖြစ်ပါတယ်။ ဒါပေမယ့် ခုချိန်ထိ ဖောင်ထဲမှာ ဒေတာတွေ ကျွန်တော်တို့မှာ မရှိသေးပါဘူး။

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

children array ထဲကို တည်းဖြတ်ခြင်းအတွက် လမ်းကြောင်း object ကို ထည့်ပါ။

ကိုယ့်ရဲ့ EditStudent function အတွက် သင်ခန်းစာမှာ လိုအပ်တဲ့ code တွေကို ထည့်ပါ။

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