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:

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;
}

亲自试一试