⊗jsrtPmCpPS 85 of 112 menu

React တွင် မိဘမှ ကလေး components များသို့ state များ လွှဲပြောင်းပေးခြင်း

ကျွန်ုပ်တို့တွင် ထုတ်ကုန်များ ပါဝင်သော array တစ်ခု ရှိသည်ဆိုပါစို့။

const initProds = [ {id: id(), name: 'product1', cost: 100}, {id: id(), name: 'product2', cost: 200}, {id: id(), name: 'product3', cost: 300}, ];

ဒီ array ကို Products component ထဲတွင် ထားမည်ဆိုပါစို့။ ထိုထုတ်ကုန်များကို component ၏ state ထဲသို့ ရေးထည့်ပါမည်။

function Products() { const [prods, setProds] = useState(initProds); }

ယခု ထုတ်ကုန်များကို loop ဖြင့် ပတ်ပြီး ၎င်းတို့ကို မည်သည့် layout ထဲမဆို ပြသပါစို့။

function Products() { const [prods, setProds] = useState(initProds); const items = prods.map(prod => { return <div key={prod.id}> name: <span>{prod.name}</span>, cost: <span>{prod.cost}</span> </div>; }); return <div> {items} </div>; }

မြင်တွေ့ရသည့်အတိုင်း ကျွန်ုပ်တို့၏ map loop အတွင်းရှိ အကြောင်းအရာသည် အတော်လေး ရှုပ်ထွေးပါသည်။ အထူးသဖြင့် နောက်ပိုင်းတွင် ထုတ်ကုန်၏ layout များ ပိုမိုကြီးထွားလာပါက ဖြစ်သည်။ ထိုသို့သော ရှုပ်ထွေးမှုသည် ကုဒ်ကို ဖတ်ရှုနားလည်ခြင်းနှင့် ထိန်းသိမ်းခြင်းကို ခက်ခဲစေပါသည်။

ထုတ်ကုန်တစ်ခုအား ပြသခြင်းအတွက် တာဝန်ယူထားသော ကုဒ်ကို သီးခြား component တစ်ခုအဖြစ် ခွဲထုတ်လိုက်ခြင်းက ပိုကောင်းပါလိမ့်မည်။ ကျွန်ုပ်တို့က ၎င်းကို Product ဟု အမည်ပေးပါမည်။ ဒီမှာ ကျွန်ုပ်တို့၏ component ကုဒ်ဖြစ်သည်။

function Product({ name, cost }) { return <div> name: <span>{name}</span>, cost: <span>{cost}</span> </div>; }

ယခု Products component အတွင်း၌ map loop အတွင်းတွင် ကလေး components Product များကို အသုံးပြုပါစို့။

function Products() { const [prods, setProds] = useState(initProds); const items = prods.map(prod => { return <Product key ={prod.id} name={prod.name} cost={prod.cost} />; }); return <div> {items} </div>; }

မြင်တွေ့ရသည့်အတိုင်း ယခုအခါ loop ၏ ကုဒ်သည် ပိုမိုရိုးရှင်းလာပြီး နားလည်ရန် ပိုမိုလွယ်ကူလာပါသည်။ ထို့အပြင် ယခုအခါ ထုတ်ကုန်များကို ပြသခြင်းအတွက် တာဝန်ယူထားသည်မှာ သီးခြား component တစ်ခုဖြစ်ပြီး ၎င်းတွင် ကျွန်ုပ်တို့သည် ထုတ်ကုန်များ၏ layout ကို ဖန်တီးပြီးနောက် တည်းဖြတ်နိုင်ပါသည်။

နည်းပညာအရ ကျွန်ုပ်တို့တွင် မိဘ component သည် ဒေတာများဖြင့် state ရှိပြီး ကလေး components များသည် ထိုဒေတာများကို props အဖြစ် လက်ခံရရှိပြီး ကျွန်ုပ်တို့လိုအပ်သောပုံစံဖြင့် ၎င်းတို့ကို ပြသပေးပါသည်။

Users component ၏ state တွင် အောက်ပါ array ကို ပေးထားသည်။

const initUsers = [ {id: id(), name: 'user1', surname: 'surn1', age: 30}, {id: id(), name: 'user2', surname: 'surn2', age: 31}, {id: id(), name: 'user3', surname: 'surn3', age: 32}, ];

ဒီ array ကို loop ဖြင့် ပတ်ပြီး user အားလုံးကို စကရင်ပေါ်တွင် ပြပါ။ user တစ်ဦးကို ပြသရန်အတွက် သီးခြား component User တစ်ခု ဖန်တီးပါ။

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