⊗jsrtPmHkURD 13 of 47 menu

React တွင် DOM အတွက် useRef ဟုက်ကို အသုံးပြုခြင်း

ယခင်သင်ခန်းစာတစ်ခုတွင်၊ refs များကို DOM element များကို လက်လှမ်းမီရန် အများဆုံးအသုံးပြုကြောင်း ဖော်ပြခဲ့ပါသည်။

ဥပမာ၊ element တစ်ခုပေါ်တွင် အာရုံစိုက်ရန်၊ scroll လုပ်ရန် သို့မဟုတ် ၎င်း၏အရွယ်အစားနှင့် တည်နေရာကို တွက်ချက်ရန် လိုအပ်သည့်အခါ၊ သို့မဟုတ် ၎င်း၏ method များ သို့မဟုတ် property များကို အသုံးပြုလိုသည့်အခါ refs များက အကူအညီပေးပါလိမ့်မည်။ ဤကဲ့သို့သော အရာများအတွက် React တွင် တည်ဆောက်ထားသော method များ မရှိသောကြောင့်ဖြစ်သည်။

input နှင့်ဥပမာတစ်ခုကို ကြည့်ကြပါစို့။ input နှင့် button ပါသော component တစ်ခုကို ဖန်တီးကြပါမည်။

return ( <div> <input /> <button>focus</button> </div> );

ပထမဦးစွာ၊ component ထဲသို့ useRef ကို import လုပ်ပါမည်။

import { useRef } from 'react';

Component ထဲတွင် ref ref တစ်ခု သတ်မှတ်ပါမည်။ ၎င်းကို null တန်ဖိုးဖြင့် အစပြုပါမည်။

const ref = useRef(null);

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

<button onClick={handleClick}>focus</button>

input ကို လက်လှမ်းမီနိုင်ရန်၊ ကျွန်ုပ်တို့၏ ref ref ကို input ၏ attribute ref ထဲသို့ ရေးထည့်ပါမည်။ ဤနည်းအားဖြင့်၊ React သည် ဤ input အတွက် DOM node ကို ဖန်တီးသည့်အခါ၊ ၎င်းသည် ၎င်းထံသို့ link တစ်ခုကို ref.current ထဲတွင် ထားရစ်ပြီး ကျွန်ုပ်တို့သည် input ၏ method များကို အသုံးပြုနိုင်မည်ဖြစ်သည်။

<input ref={ref} />

နောက်ဆုံးအနေဖြင့်၊ button ကို ကလစ်နှိပ်လိုက်သည့်အခါ input ပေါ်တွင် အာရုံစိုက်မှု ရောက်စေရန် ကလစ်နှိပ်ခြင်းကို ကိုင်တွယ်သည့် function ကို ထည့်သွင်းပါမည်။ ယခု ကျွန်ုပ်တို့သည် ၎င်းကို ref မှတစ်ဆင့် လုပ်ဆောင်နိုင်ပြီဖြစ်သည်။ ref ထဲတွင် ကျွန်ုပ်တို့၏ input သို့ link တစ်ခု ရှိနေပြီး ၎င်း၏ method focus ကို ခေါ်ယူခြင်းဖြင့် လုပ်ဆောင်နိုင်ပါသည်။

function handleClick() { ref.current.focus(); }

Button ကို နှိပ်ကြည့်ပြီး input ပေါ်သို့ အာရုံစိုက်မှု ရောက်ရှိကြောင်း သေချာစေပါ။

ဤသင်ခန်းစာတွင် ကျွန်ုပ်တို့ ရေးသားခဲ့သော App component ၏ code ကို ယူပြီး၊ button ကို ကလစ်နှိပ်လိုက်သည့်အခါ input ထဲတွင် အာရုံစိုက်မှုရောက်ခြင်းအပြင် ထည့်သွင်းမှုကွက်လပ်ကိုလည်း ရှင်းလင်းပေးသည့်အတိုင်း ပြုလုပ်ပါ။ ဤအတွက် input ၏ property value ကို အသုံးပြုပါ။

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