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:)
⊗jsrtPmHkUTr 17 of 47 menu

React တွင် စွမ်းဆောင်ရည် အကောင်းဆုံးဖြစ်အောင် ပြုလုပ်ရန် useTransition ဟုခ်

စွမ်းဆောင်ရည် အကောင်းဆုံးဖြစ်အောင် ပြုလုပ်ရန် useTransition ဟုခ်သည် ကျွန်ုပ်တို့အား ရုပ်မြင်အင်တာဖေ့စ်ကို ပိတ်ပင်တားဆီးခြင်းမရှိဘဲ state များကို အပ်ဒိတ်လုပ်ခွင့်ပြုသည်။

ဤဟုခ်ကို အသုံးပြု၍ ကျွန်ုပ်တို့သည် မည်သည့် state တစ်ခု၏ အပ်ဒိတ်ကိုမဆို ဦးစားပေးမှုနိမ့်အောင် သတ်မှတ်ပေးနိုင်ပြီး အခြား state များ၏ အပ်ဒိတ်များသည် ဦးစားပေးမှုမြင့်မားစေကာ အနှောင့်အယှက်မရှိ လုပ်ဆောင်နိုင်စေရန် ဖြစ်သည်။

ဥပမာအနေဖြင့် ရှာဖွေရေးအကွက်တွင် အသုံးပြုသူက စာလုံးများ ရိုက်ထည့်သည့်အခါ ကုန်ပစ္စည်းများ အောက်ကျဆင်းစာရင်း (dropdown list) ကို စစ်ထုတ်ခြင်းကို ဖော်ပြနိုင်ပါသည်။ ဟုတ်ပါသည်၊ စာရင်းကိုယ်တိုင်သည် အနည်းငယ် နှောင့်နှေးမှုဖြင့် ပြသနိုင်သော်လည်း ရှာဖွေရေးအကွက်ထဲသို့ စာလုံးများ ရိုက်ထည့်ရာတွင် နှောင့်နှေးမှုဖြင့် ဖြစ်စေလိုမည် မဟုတ်ပါ။

ထိုကဲ့သို့သော အခြေအနေများတွင် useTransition ဟုခ်က မည်သို့ ကူညီနိုင်သည်ကို ကြည့်ရအောင်။ ကျွန်ုပ်တို့တွင် အဓိက ကွန်ပြူနာရဲ့ ကုဒ်အပိုင်းအစတစ်ခု ရှိသည်ဟု ယူဆပါစို့။ ထိုကုဒ်ကို စိစစ်လေ့လာကြည့်ကြပါစို့။

import { useTransition } from 'react'; import { useState } from 'react'; function App() { const [isPending, startTransition] = useTransition(); const [filterTerm, setFilterTerm] = useState(''); const filteredProducts = filterProducts(filterTerm); function updateFilterHandler(event) { startTransition(() => { setFilterTerm(event.target.value); }); } return ( <div> <input type="text" onChange={updateFilterHandler} /> <ProductList products={filteredProducts} /> </div> ); }

ဤနေရာတွင် ကျွန်ုပ်တို့သည် useTransition အတွက် ကိုယ်စားပြုမှုနှစ်ခုကို မြင်တွေ့ရပါသည်။ isPending ကိုယ်စားပြုမှုသည် ဗူးလီယန်တန်ဖိုးကို ထိန်းသိမ်းထားပြီး အပ်ဒိတ်လုပ်ငန်းစဉ် ပြီးဆုံးပြီ မပြီးဆုံးသေးဘူးကို ပြသပါသည်။ startTransition လုပ်ဆောင်ချက်သည် အပ်ဒိတ်၏ ဦးစားပေးမှုကို လျှော့ချခွင့်ပြုသော လုပ်ဆောင်ချက် ဖြစ်သည်။

const [isPending, startTransition] = useTransition();

ထို့အပြင် ကျွန်ုပ်တို့တွင် filterTerm state ရှိပါသည်။ ၎င်းတွင် အင်ပူ့ထဲသို့ ရိုက်ထည့်ထားသော စကားစုကို သိမ်းဆည်းထားပြီး setFilterTerm လုပ်ဆောင်ချက်သည် ၎င်းကို သတ်မှတ်ရန် ဖြစ်သည်။

const [filterTerm, setFilterTerm] = useState('');

အင်ပူ့ထဲသို့ စာလုံးများ ရိုက်ထည့်သည့်အခါတိုင်း updateFilterHandler လုပ်ဆောင်ချက်ကို အကြိမ်တိုင်း ခေါ်ယူပါသည်။ ၎င်းအတွင်း၌ filterTerm ကို အပ်ဒိတ်လုပ်ခြင်း ဖြစ်ပေါ်ပါသည်။ ဤနေရာမှာပင် ကျွန်ုပ်တို့သည် ကျွန်ုပ်တို့၏ useTransition ဟုခ်ကို အသုံးပြုပါသည်။ သတ်မှတ်ရန် လုပ်ဆောင်ချက် setFilterTerm ကို startTransition ထဲသို့ အောက်ပါအတိုင်း ထည့်သွင်းထားခြင်း ဖြစ်သည်။

function updateFilterHandler(event) { startTransition(() => { setFilterTerm(event.target.value); }); }

ဤနည်းအားဖြင့် state filterTerm အတွက် ဦးစားပေးမှုနိမ့်အောင် သတ်မှတ်လိုက်ပြီး ကျွန်ုပ်တို့၏ အင်ပူ့အကွက်သည် တုံ့ပြန်မှုကောင်းမွန်စွာ ကျန်ရှိနေပါမည်။

isPending ကိုယ်စားပြုမှုကို အသုံးပြု၍ စာရင်း အပ်ဒိတ်လုပ်ဆဲဖြစ်ကြောင်း အသုံးပြုသူထံ ပြသနိုင်ပါသည်။ စာရင်း အပ်ဒိတ်လုပ်နေစဉ် ဤသတင်းအချက်အလက်ကို အင်ပူ့အကွက်၏အောက်တွင် ဖော်ပြကြည့်ကြပါစို့။

return ( <div> <input type="text" onChange={updateFilterHandler} /> {isPending && <p>updating ...</p>} <ProductList products={filteredProducts} /> </div> );
မြန်မာ
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 များကို အသုံးပြုပါသည်။ ဒေတာများကို ပြုပြင်ခြင်းသည် ကိုယ်ရေးကိုယ်တာ မူဝါဒအတိုင်း ဖြစ်ပါသည်။
အားလုံးလက်ခံရန် ပြင်ဆင်ရန် ငြင်းပယ်ရန်