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:)
⊗jsrtPmHkUEGH 6 of 47 menu

React တွင် useEffect မှတဆင့် Global Event Handlers များ

ယခုကျွန်ုပ်တို့လိုချင်သည်မှာ ခလုတ်ကိုနှိပ်ခြင်းဖြင့်သာမက ကီးဘုတ်ပေါ်ရှိ Enter ကိုနှိပ်ခြင်းဖြင့်လည်း အရောင်ပြောင်းလိုပါသည်။ သာမန် React ဘဝတွင် global object window ကို addEventListener ဖြင့် နားထောင်ခြင်းမပြုလုပ်နိုင်ပါ။ ၎င်းအတွက် ကျွန်ုပ်တို့တွင် effects များရှိပါသည်။ useEffect ကိုအသုံးပြု၍ ဤလုပ်ဆောင်ချက်ကို ထည့်သွင်းကြပါစို့။

Enter ကိုနှိပ်သည့်အခါ အရောင်အနီသို့ပြောင်းစေမည့် function တစ်ခုကိုရေးကြပါစို့။

function handleEnter(event) { if (event.keyCode === 13) { setColor('red'); } }

ယခု event listener ကို window သို့ useEffect hook အတွင်းတွင် ချိတ်ဆက်ကြပါစို့။

useEffect(() => { document.body.style.color = color; window.addEventListener('keydown', handleEnter); }, [color]);

တည်ဆောက်သည့် function ရှိပါက အနာဂတ်တွင် ပြဿနာများကိုရှောင်ရှားရန် သန့်ရှင်းရေး (cleanup) သို့မဟုတ် စာရင်းမှထုတ်ခြင်း (unsubscribe) code ကို useEffect အတွင်း၌ အမြဲပြန်ပေးရပါမည်။ ဤကိစ္စတွင် addEventListener ချိတ်ဆက်ပြီးနောက် ၎င်း၏ဖျက်ခြင်းကို ပြန်ပေးရပါမည်။

useEffect(() => { document.body.style.color = color; window.addEventListener('keydown', handleEnter); return () => { window.removeEventListener('keydown', handleEnter); }; }, [color]);

Component တစ်ခုပေးထားသည်။ စာမျက်နှာ၏ မည်သည့်နေရာကိုမဆိုနှိပ်လိုက်သည့်အခါ ထို component ၏ background အရောင်ပြောင်းသွားစေရန် လုပ်ဆောင်ပေးပါ။

�ှိပ်လိုက်သည့်အခါ block တစ်ခုပေါ်လာမည့် �င့်ခ်တစ်ခုလုပ်ပါ။ Browser window ၏ မည်သည့်နေရာကိုမဆို နှိပ်လိုက်သည့်အခါတိုင်း ကျွန်ုပ်တို့၏ block ကို ပိတ်သွားစေရန် လုပ်ဆောင်ပေးပါ။

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