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