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:)
⊗jsSpExcDAE 148 of 294 menu

JavaScript တွင် data- attributes များနှင့် ခြွင်းချက် ဥပမာ

စာမျက်နှာ စတင်တင်လိုက်သည့်အခါ ဆာဗာမှ ထုတ်ကုန်အမည်၊ ဈေးနှုန်းနှင့် ဝယ်ယူထားသော အရေအတွက်ကို သိမ်းဆည်းထားသည့် HTML ကုဒ်ကို ဖန်တီးပေးသည်ဆိုပါစို့။

<div id="product" data-product="ပန်းသီး" data-price="1000" data-amount="5"></div>

ထုတ်ကုန်ပါဝင်သည့် element ဆီသို့ လက်ခံရရှိသည့် လင့်ခ်ကို ယူ၍ ထုတ်ကုန်၏ စုစုပေါင်းကုန်ကျမှု (ဈေးနှုန်းနှင့် အရေအတွက်ကို မြှောက်ခြင်း) ကို ရှာဖွေပေးမည့် function တစ်ခု ပြုလုပ်ကြည့်ရအောင်။

function getCost(elem) { return elem.dataset.price * elem.dataset.amount; }

ကျွန်ုပ်တို့၏ ထုတ်ကုန်၏ ကုန်ကျမှုကို ရှာကြည့်ပါမည်။

let product = document.querySelector('#product'); let cost = getCost(product); alert(cost);

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

<div id="product" data-product="ပန်းသီး" data-price="1000"></div>

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

ဆိုလိုသည်မှာ ကျွန်ုပ်တို့လိုအပ်သည့် attributes များ ပျောက်ဆုံးနေခြင်းမှ အကာအကွယ်ပေးရန် လိုအပ်သည်။ ၎င်းကို နည်းလမ်း နှစ်မျိုးဖြင့် လုပ်ဆောင်နိုင်သည်။ ပထမနည်းလမ်းမှာ ၎င်းသည် သာမန် အပြုအမူတစ်ခုဖြစ်သည်ဟု ဆိုပြီး if များဖြင့် လိုအပ်သည့် attributes များ ရှိမရှိ စစ်ဆေးခြင်း ဖြစ်သည်။

function getCost(elem) { if (elem.dataset.price !== undefined && elem.dataset.amount !== undefined) { return elem.dataset.price * elem.dataset.amount; } else { return 0; // တစ်ခုခုကို ပြန်ပေးမည်၊ ဥပမာ 0 သို့မဟုတ် null သို့မဟုတ် false } }

ဒုတိယ ရွေးချယ်စရာမှာ data-price သို့မဟုတ် data-amount attribute မရှိခြင်းသည် ခြွင်းချက်ဖြစ်ရပ်တစ်ခုဟု ဆိုခြင်းဖြစ်သည်။ ဤအခြေအနေတွင် ကျွန်ုပ်တို့သည် ခြွင်းချက်ကို ပစ်ထုတ်မည်ဖြစ်သည်။

function getCost(elem) { if (elem.dataset.price !== undefined && elem.dataset.amount !== undefined) { return elem.dataset.price * elem.dataset.amount; } else { throw { name: 'ProductCostError', message: 'ထုတ်ကုန်တွင် ဈေးနှုန်း သို့မဟုတ် အရေအတွက် ပျောက်ဆုံးနေသည်' }; } }

ဤနေရာတွင် မည်သည့်ရွေးချယ်မှုကို အသုံးပြုရန် ပိုမိုသင့်လျော်သည် ဆိုသည်မှာ ပရိုဂရမ်မာ၏ ရွေးချယ်မှုပေါ်တွင် မူတည်သည်။ ၎င်းသည် ပြဿနာကို စက္ကရစ်၏ သာမန်အလုပ်တစ်ခုအဖြစ် သို့မဟုတ် ခြွင်းချက်ဖြစ်ရပ်တစ်ခုအဖြစ် ယူဆနိုင်သည်။

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

let product = document.querySelector('#product'); try { let cost = getCost(product); alert(cost); } catch (error) { // ခြွင်းချက်ကို တစ်နည်းနည်းဖြင့် တုံ့ပြန်မည် }

�ျွန်ုပ်၏ကုဒ်ကို getCost function မှ ခြွင်းချက်နှစ်မျိုးကို ပစ်ထုတ်နိုင်ရန် ပြန်လည်ပြင်ဆင်ပါ။ ဈေးနှုန်း ပျောက်ဆုံးပါက နှင့် အရေအတွက် ပျောက်ဆုံးပါက ဟူ၍ဖြစ်သည်။ ထိုခြွင်းချက်များ၏ အမည်များကို ကောင်းစွာ စဉ်းစားပါ။ catch ဘလောက်အတွင်းတွင် အမျိုးအစားကွဲပြားသည့် ခြွင်းချက်များအတွက် ကွဲပြားသည့် အမှားမှတ်တမ်းစာသားများကို ပြသပါ။

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