JS ကျူတိုရီရယ်

JS ပင်မ JS မိတ်ဆက် JS ဘယ်သွားမလဲ။ JS Output JS ထုတ်ပြန်ချက် JS Syntax JS မှတ်ချက်များ JS အပြောင်းအလဲများ JS Let JS Const JS အော်ပရေတာများ JS ဂဏန်းသင်္ချာ JS တာဝန် JS ဒေတာအမျိုးအစားများ JS လုပ်ဆောင်ချက်များ JS အရာဝတ္ထုများ JS ပွဲများ JS စာတန်းများ JS စာတန်းနည်းလမ်းများ JS စာတန်းရှာဖွေမှု JS String Templates JS နံပါတ်များ JS နံပါတ်နည်းလမ်းများ JS Arrays JS Array Methods JS Array အမျိုးအစား JS Array Iteration JS Array Const JS ရက်စွဲများ JS ရက်စွဲပုံစံများ JS နေ့စွဲ နည်းလမ်းများ ရယူပါ။ JS ရက်စွဲ သတ်မှတ်နည်းလမ်းများ JS သင်္ချာ JS Random JS Booleans JS နှိုင်းယှဉ်မှုများ JS အခြေအနေများ JS Switch JS Loop For JS Loop For In JS Loop For Of JS Loop While JS Break JS Iterables JS အစုံများ JS Maps JS အမျိုးအစား JS အမျိုးအစား ပြောင်းခြင်း။ JS Bitwise JS RegExp JS အမှားများ JS နယ်ပယ် JS Hoisting JS တင်းကျပ်သောမုဒ် JS ဒီ Keyword ပါ။ JS Arrow Function JS သင်တန်းများ JS JSON JS Debugging JS စတိုင်လမ်းညွှန် JS အကောင်းဆုံးအလေ့အကျင့်များ JS အမှားများ JS စွမ်းဆောင်ရည် JS သီးသန့်စကားလုံးများ

JS ဗားရှင်းများ

JS ဗားရှင်းများ JS 2009 (ES5) JS 2015 (ES6) JS 2016 JS 2017 JS 2018 JS IE / Edge JS သမိုင်း

JS အရာဝတ္ထုများ

Object အဓိပ္ပါယ်ဖွင့်ဆိုချက် Object Properties များ အရာဝတ္ထုနည်းလမ်းများ အရာဝတ္ထုပြသခြင်း။ အရာဝတ္ထု ဆက်စပ်ပစ္စည်းများ Object Constructors များ Object Prototypes Object Iterables အရာဝတ္ထုအစုံများ အရာဝတ္ထုမြေပုံများ Object ကိုးကား

JS လုပ်ဆောင်ချက်များ

လုပ်ဆောင်ချက် အဓိပ္ပါယ်ဖွင့်ဆိုချက် လုပ်ဆောင်ချက် ကန့်သတ်ချက်များ Function Invocation လုပ်ဆောင်ချက်ခေါ်ဆိုမှု လုပ်ဆောင်ချက်ကို အသုံးပြုပါ။ Function ပိတ်ခြင်းများ

JS သင်တန်းများ

အတန်းမိတ်ဆက် Class Inheritance အတန်းထဲမှာလည်း

JS Async

JS ပြန်ခေါ်မှုများ JS Asynchronous JS ကတိများ JS Async/Await

JS HTML DOM

DOM မိတ်ဆက် DOM နည်းလမ်းများ DOM စာရွက်စာတမ်း DOM ဒြပ်စင်များ DOM HTML DOM ပုံစံများ DOM CSS DOM အန်နီမေးရှင်းများ DOM ပွဲများ DOM ဖြစ်ရပ် နားထောင်သူ DOM လမ်းညွှန် DOM Nodes DOM စုစည်းမှုများ DOM Node စာရင်းများ

JS Browser BOM

JS Window JS မျက်နှာပြင် JS တည်နေရာ JS သမိုင်း JS Navigator JS Popup သတိပေးချက် JS Timing JS Cookies

JS ဝဘ် API များ

ဝဘ် API မိတ်ဆက် ဝဘ်ဖောင် API ဝဘ်သမိုင်း API ဝဘ်သိုလှောင်မှု API Web Worker API Web Fetch API ဝဘ် Geolocation API

JS AJAX

AJAX နိဒါန်း AJAX XMLHttp AJAX တောင်းဆိုချက် AJAX တုံ့ပြန်မှု AJAX XML ဖိုင် AJAX PHP AJAX ASP AJAX ဒေတာဘေ့စ် AJAX အပလီကေးရှင်းများ AJAX ဥပမာများ

JS JSON

JSON မိတ်ဆက် JSON Syntax JSON နှင့် XML JSON ဒေတာအမျိုးအစားများ JSON Parse JSON Stringify JSON အရာဝတ္ထုများ JSON Arrays JSON ဆာဗာ JSON PHP JSON HTML JSON JSONP

JS နှင့် jQuery

jQuery ရွေးချယ်မှုများ jQuery HTML jQuery CSS jQuery DOM

JS ဂရပ်ဖစ်

JS ဂရပ်ဖစ် JS Canvas JS Plotly JS Chart.js JS Google Chart JS D3.js

JS ဥပမာများ

JS ဥပမာများ JS HTML DOM JS HTML ထည့်သွင်းမှု JS HTML Objects JS HTML ပွဲများ JS Browser JS တည်းဖြတ်သူ JS လေ့ကျင့်ခန်းများ JS Quiz JS လက်မှတ်

JS ကိုးကားချက်များ

JavaScript Objects HTML DOM အရာဝတ္ထုများ


ECMAScript 2017

JavaScript အမည်ပေးခြင်း သဘောတူညီချက်ကို ES1၊ ES2၊ ES3၊ ES5 နှင့် ES6 တို့ဖြင့် စတင်ခဲ့သည်။

သို့သော်၊ ECMAScript 2016 နှင့် 2017 ကို ES7 နှင့် ES8 ဟုခေါ်သည်မဟုတ်ပါ။

2016 ခုနှစ်မှစတင်၍ ဗားရှင်းအသစ်များကို နှစ်အလိုက် (ECMAScript 2016/2017/2018) ဟု အမည်ပေးထားပါသည်။

ECMAScript 2017 တွင် အင်္ဂါရပ်အသစ်များ

ဤအခန်းသည် ECMAScript 2017 တွင် အင်္ဂါရပ်အသစ်များကို မိတ်ဆက်ပေးသည်-


JavaScript String Padding

ECMAScript 2017 သည် String နည်းလမ်းနှစ်ခုကို ပေါင်းထည့်ထားသည်- padStart နှင့် padEndstring တစ်ခု၏ အစနှင့် အဆုံးတွင် padding ကို ပံ့ပိုးရန်။

ဥပမာ

let str = "5";
str = str.padStart(4,0);
// result is 0005

ဥပမာ

let str = "5";
str = str.padEnd(4,0);
// result is 5000

String Padding ကို Internet Explorer တွင် မပံ့ပိုးပါ။

Firefox နှင့် Safari တို့သည် JavaScript string padding အတွက် ပထမဆုံးသော browser များဖြစ်သည်-

Chrome 57 Edge 15 Firefox 48 Safari 10 Opera 44
Mar 2017 Apr 2017 Aug 2016 Sep 2016 Mar 2017

JavaScript Object ထည့်သွင်းမှုများ

Object.entriesECMAScript 2017 သည် အရာဝတ္ထုများသို့ နည်းလမ်း အသစ်တစ်ခုကို ပေါင်းထည့်သည် ။

Object.entries() နည်းလမ်းသည် အရာဝတ္ထုတစ်ခုရှိ သော့/တန်ဖိုးအတွဲများ၏ array တစ်ခုကို ပြန်ပေးသည်-

ဥပမာ

const person = {
  firstName : "John",
  lastName : "Doe",
  age : 50,
  eyeColor : "blue"
};
document.getElementById("demo").innerHTML = Object.entries(person);

Object.entries() သည် loops များတွင် အရာဝတ္ထုများကို အသုံးပြုရန် ရိုးရှင်းစေသည်။

ဥပမာ

const fruits = {Bananas:300, Oranges:200, Apples:500};

let text = "";
for (let [fruit, value] of Object.entries(fruits)) {
text += fruit + ": " + value + "
";
}

Object.entries() သည် အရာဝတ္ထုများကို မြေပုံများအဖြစ် ပြောင်းရန် ရိုးရှင်းစေသည်-

ဥပမာ

const fruits = {Bananas:300, Oranges:200, Apples:500};

const myMap = new Map(Object.entries(fruits));

Chrome နှင့် Firefox သည် အောက်ပါတို့အတွက် ပံ့ပိုးမှုရှိသော ပထမဆုံးဘရောက်ဆာများဖြစ်သည် Object.entries

Chrome 47 Edge 14 Firefox 47 Safari 10.1 Opera 41
Jun 2016 Aug 2016 Jun 2016 Mar 2017 Oct 2016

JavaScript Object တန်ဖိုးများ

Object.valuesတူညီကြသည် Object.entries၊ သို့သော် အရာဝတ္ထုတန်ဖိုးများ၏ အတိုင်းအတာတစ်ခုတည်း ခင်းကျင်းခြင်းကို ပြန်ပေးသည်-

ဥပမာ

const person = {
  firstName : "John",
  lastName : "Doe",
  age : 50,
  eyeColor : "blue"
};
document.getElementById("demo").innerHTML = Object.values(person);

Firefox နှင့် Chrome သည် အောက်ပါတို့အတွက် ပံ့ပိုးမှုရှိသော ပထမဆုံးဘရောက်ဆာများဖြစ်သည် Object.values

Chrome 54 Edge 14 Firefox 47 Safari 10.1 Opera 41
Oct 2016 Aug 2016 Jun 2016 Mar 2017 Oct 2016


JavaScript Async လုပ်ဆောင်ချက်များ

အချိန်ကုန်ရန် စောင့်နေသည်။

async function myDisplay() {
  let myPromise = new Promise(function(myResolve, myReject) {
    setTimeout(function() { myResolve("I love You !!"); }, 3000);
  });
  document.getElementById("demo").innerHTML = await myPromise;
}

myDisplay();

Firefox နှင့် Chrome တို့သည် async JavaScript လုပ်ဆောင်ချက်များကို ပံ့ပိုးပေးသည့် ပထမဆုံးဘရောက်ဆာများဖြစ်သည်-

Chrome 55 Edge 15 Firefox 52 Safari 11 Opera 42
Dec 2016 Apr 2017 Mar 2017 Sep 2017 Dec 2016