Muungano wa ECMAScript 2019
Namba ya versioning ya JavaScript
Mifano ya JavaScript ya zamani inaitwa kwa namba: ES5 (2009) na ES6 (2015).
Kuanzia 2016, versioning inaitwa kwa miaka: ECMAScript 2016, 2017, 2018, 2019, ...
Tabia zitaongezwa zaidi ya ES2019:
- String.trimStart()
- String.trimEnd()
- Object.fromEntries
- Kuwa na kipakusha cha catch
- Array.flat()
- Array.flatMap()
- Array.Sort() inareviswa tena
- Kurevishe cha JSON.stringify
- Makadara yanayowasiliana kwenye matukio ya kiroho
- Function.toString() inareviswa tena
Ujumbe wa kina
Tabia hizi ni zimeongezwa kwa muda mwingi.
Mifano ya vifaa vya zamani yanaweza kutumia maelezo ya kina (Polyfill)
Method ya kichwa cha kifupi cha JavaScript
ES2019 inaongeza methodi ya String kwa JavaScript trimStart()
。
trimStart()
habari ya kazi ya methodi inayotumika kama trim()
kwa hivyo, lakini tuonesha spasi kwenye kizani cha kwanza cha kiroho.
实例
let text1 = " Hello World! "; let text2 = text1.trimStart();
Kuanzia Januari 2020, tabia zote za mifano ya hali ya kawaida zinaongoza JavaScript String trimStart():
Chrome | Edge | Firefox | Safari | Opera |
---|---|---|---|---|
Chrome 66 | Edge 79 | Firefox 61 | Safari 12 | Opera 50 |
2018 年 4 月 | 2020 年 1 月 | 2018 年 6 月 | 2018 年 9 月 | 2018 年 5 月 |
Method ya kichwa cha kifupi cha JavaScript
ES2019 为 JavaScript 添加了 trimEnd()
method ya kiroho.
trimEnd()
habari ya kazi ya methodi inayotumika kama trim()
kwa hivyo, lakini tuonesha spasi kwenye kizani cha kikuu cha kiroho.
实例
let text1 = " Hello World! "; let text2 = text1.trimEnd();
自 2020 年 1 月以来,所有现代浏览器都支持 JavaScript String trimEnd():
Chrome | Edge | Firefox | Safari | Opera |
---|---|---|---|---|
Chrome 66 | Edge 79 | Firefox 61 | Safari 12 | Opera 50 |
2018 年 4 月 | 2020 年 1 月 | 2018 年 6 月 | 2018 年 9 月 | 2018 年 5 月 |
Method ya kufa kwa kuzingatia kwa JavaScript
ES2019 为 JavaScript 添加了 fromEntries()
对象方法。
fromEntries()
方法从可迭代的键/值对创建对象。
实例
const fruits = [ ["apples", 300], ["pears", 900], ["bananas", 500] ]; const myObj = Object.fromEntries(fruits);
自 2020 年 1 月以来,所有现代浏览器都支持 JavaScript Object fromEntries():
Chrome | Edge | Firefox | Safari | Opera |
---|---|---|---|---|
Chrome 73 | Edge 79 | Firefox 63 | Safari 12.1 | Opera 60 |
2019 年 3 月 | 2020 年 1 月 | 2018 年 10 月 | 2019 年 3 月 | 2019 年 4 月 |
Kuwa na kipakusha cha catch
从 ES2019 开始,如果不需要,可以省略 catch 参数:
实例
2019 年之前:
try { // code } catch (err) { // code }
2019 年后:
try { // code } catch { // code }
自 2020 年 1 月以来,所有现代浏览器都支持可选的 catch 绑定:
Chrome | Edge | Firefox | Safari | Opera |
---|---|---|---|---|
Chrome 66 | Edge 79 | Firefox 58 | Safari 11.1 | Opera 53 |
2018 年 4 月 | 2020 年 1 月 | 2018 年 1 月 | 2018 年 3 月 | 2018 年 5 月 |
Method ya kufa kwa matukio ya JavaScript
ES2019 为 JavaScript 添加了 flat()
数组方法。
flat()
方法通过展平嵌套数组来创建新数组。
实例
const myArr = [[1,2],[3,4],[5,6]]; const newArr = myArr.flat();
自 2020 年 1 月以来,所有现代浏览器都支持 JavaScript Array flat():
Chrome | Edge | Firefox | Safari | Opera |
---|---|---|---|---|
Chrome 69 | Edge 79 | Firefox 62 | Safari 12 | Opera 56 |
2018 年 9 月 | 2020 年 1 月 | 2018 年 9 月 | 2018 年 9 月 | 2018 年 9 月 |
Method ya kufa kwa matukio ya JavaScript
ES2019 为 JavaScript 添加了 flatMap()
数组方法。
flatMap()
方法首先映射数组的所有元素,然后通过展平数组来创建新数组。
实例
const myArr = [1, 2, 3, 4, 5, 6]; const newArr = myArr.flatMap((x) => x * 2);
Method ya kusort kwa matukio ya JavaScript
ES2019 修订Kwa mtindo wa Array sort().
Kwenye ES2019 kabla, shabiki za mtindo wa kusortisha haikupatikana, kama QuickSort.
Kwenye ES2019 baada ya, inafaa kwa vifaa vya ingawa kwa uharibifu wa usababishaji wa mawazo.
Kama kufikia uwezo wa kusortisha kwa matokeo wa ukweli, elementi hayo lazima iwe na uwanja wa mawazo na elementi zilizotumika kwa ukweli.
实例
const myArr = [ {name:"X00",price:100 }, {name:"X01",price:100 }, {name:"X02",price:100 }, {name:"X03",price:100 }, {name:"X04",price:110 }, {name:"X05",price:110 }, {name:"X06",price:110 }, {name:"X07",price:110 } ];
Kwenye matokeo ya maelezo yenye umuhimu wa kulingana na kiasi cha kawaida, hayo hayakupatikana katika hali za uwanja wa mawazo, kama iliyotazwa hapa:
X01 100 X03 100 X00 100 X03 100 X05 110 X04 110 X06 110 X07 110
Kurevishe cha JSON.stringify
ES2019 修订Kwa mtindo wa JSON.stringify().
Kwenye ES2019 kabla, JSON haaweza kutumika kwa chaji zilizochaguliwa na \.
实例
let text = JSON.stringify("\u26D4");
Kwenye ES2019 kabla, JSON.stringify() kwa chaji cha chaji UTF-8 (U+D800 hadi U+DFFF) inatokana na chaji cha Unicode yenye kusababisha kusikitika, kama ���.
Baada ya mawazo hayo, stringi za chaji UTF-8 zinaweza kutumika kwa msaada wa JSON.stringify() kwa umewagizaji wa msaada, na kureheshwa kwa JSON.parse() kuwa stringi wa orodha wa kwanza.
Simbo la kusababisha
Inasemekana kwamba stringi za maandiko inafikia hali ya mabara na mabara ya mawazo (\u2028
na \u2029
)。
Kamili, kwenye ES2019 kabla, hayo ilikuwa na matukio ya kuagiza na kusababisha kusikitika kwa kosa.
实例
// Hii inapatikana katika ES2019: let text = "\u2028";
Kuja amua
Hii sasa, JavaScript na JSON zinaonekana na kanuni zilizochaguliwa pamoja.
Kamili, JavaScript na JSON zinaonekana na kanuni zilizochaguliwa pamoja.
text = JSON.parse('"\u2028"') inapatikana kama ''.
Mengine waangalia text = '"\u2028"' inatengwaKufaa ya lugha。
Kurevishe cha Function toString
ES2019 修订了 Function toString() 方法。
toString() 方法返回表示函数源代码的字符串。
从 2019 年开始,toString() 必须返回函数的源代码,包括注释、空格和语法细节。
在 2019 年之前,不同的浏览器返回了不同的函数变体(比如没有注释和空格)。从 2019 年开始,该函数应该完全按照编写的方式返回。
实例
function myFunction(p1, p2) { return p1 * p2; }