偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

ECMAScript 最新進展匯總!

開發(fā) 前端
TC39 是一個推動 JavaScript 發(fā)展的技術(shù)委員會,由各個主流瀏覽器廠商的代表構(gòu)成,其主要工作就是制定 ECMAScript 標(biāo)準(zhǔn)。TC39 每兩個月舉行一次會議。對于新提案,從提出到最后被納入 ECMAScript 新特性。

2023 年 7 月 11 日 - 7 月 13 日,第 97 次 TC39 會議在挪威舉行,下面就來看看在這次會議中哪些 ECMAScript 提案取得了新進展吧!

TC39 是一個推動 JavaScript 發(fā)展的技術(shù)委員會,由各個主流瀏覽器廠商的代表構(gòu)成,其主要工作就是制定 ECMAScript 標(biāo)準(zhǔn)。TC39 每兩個月舉行一次會議。對于新提案,從提出到最后被納入 ECMAScript 新特性,TC39 的規(guī)范中分為五步:

  • Stage 0(strawman),任何TC39的成員都可以提交。
  • Stage 1(proposal),進入此階段就意味著這一提案被認(rèn)為是正式的了,需要對此提案的場景與API進行詳盡的描述。
  • Stage 2(draft),這一階段的提案如果能最終進入到標(biāo)準(zhǔn),那么在之后的階段都不會有太大的變化,因為理論上只接受增量修改。
  • Stage 3(candidate),這一階段的提案只有在遇到了重大問題才會修改,規(guī)范文檔需要被全面的完成。
  • Stage 4(finished),這一階段的提案將會被納入到ES每年發(fā)布的規(guī)范之中。

附: ECMAScript 2023(ES14)已于 6 月 27 日正式發(fā)布,詳見 >>> 《ECMAScript 2023 正式發(fā)布,有哪些新特性?》

Stage 3

數(shù)組分組

 提案[1] 用于簡化數(shù)組(和可迭代對象)中的分組操作。數(shù)組分組是一種非常常見的操作,其將相似的數(shù)據(jù)組合成組允許開發(fā)者計算更高階的數(shù)據(jù)集。

const array = [1, 2, 3, 4, 5];

// Object.groupBy 根據(jù)任意鍵對元素進行分組,這里通過奇偶數(shù)對元素進行分組。
Object.groupBy(array, (num, index) => {
  return num % 2 === 0 ? 'even': 'odd';
});
// =>  { odd: [1, 3, 5], even: [2, 4] }

// Map.groupBy 返回一個 Map 對象,方便使用對象鍵進行分組。
const odd  = { odd: true };
const even = { even: true };
Map.groupBy(array, (num, index) => {
  return num % 2 === 0 ? even: odd;
});
// =>  Map { {odd: true}: [1, 3, 5], {even: true}: [2, 4] }

該提案提供了兩個方法:Object.groupBy 和 Map.groupBy。前者返回一個沒有原型的對象,可以方便地進行解構(gòu)操作,并且可以防止與全局 Object 屬性發(fā)生意外沖突。后者返回一個普通的 Map 實例,可以對復(fù)雜鍵類型進行分組(比如復(fù)合鍵或元組)。

Promise.withResolvers

當(dāng)手動創(chuàng)建一個 Promise 時,用戶必須傳遞一個執(zhí)行器回調(diào)函數(shù),該函數(shù)接受兩個參數(shù):

  • resolve 函數(shù),用于觸發(fā) Promise 的解決。
  • reject 函數(shù),用于觸發(fā) Promise 的拒絕。

如果回調(diào)函數(shù)可以嵌入調(diào)用一個最終觸發(fā)解決或拒絕的異步函數(shù)(例如注冊事件監(jiān)聽器),則這種方式可以很好地工作。

const promise = new Promise((resolve, reject) => {
  asyncRequest(config, response => {
    const buffer = [];
    response.on('data', data => buffer.push(data));
    response.on('end', () => resolve(buffer));
    response.on('error', reason => reject(reason));
  });
});

然而,通常開發(fā)人員希望在實例化 Promise 后配置其解決和拒絕行為。目前,這需要一個繁瑣的解決方法,從回調(diào)范圍中提取 resolve 和 reject 函數(shù):

let resolve, reject;
const promise = new Promise((res, rej) => {
  resolve = res;
  reject = rej;
});
asyncRequest(config, response => {
  const buffer = [];
  response.on('callback-request', id => {
    promise.then(data => callback(id, data));
  });
  response.on('data', data => buffer.push(data));
  response.on('end', () => resolve(buffer));
  response.on('error', reason => reject(reason));
});

開發(fā)人員可能還有其他要求,需要將 resolve/reject 傳遞給多個調(diào)用方,因此必須以這種方式實現(xiàn):

let resolve = () => { };
let reject = () => { };

function request(type, message) {
  if (socket) {
    const promise = new Promise((res, rej) => {
      resolve = res;
      reject = rej;
    });
    socket.emit(type, message);
    return promise;
  }

  return Promise.reject(new Error('Socket unavailable'));
}

socket.on('response', response => {
  if (response.status === 200) {
    resolve(response);
  }
  else {
    reject(new Error(response));
  }
});

socket.on('error', err => {
  reject(err);
});

Promise.withResolvers[2] 提案簡單地在 Promise 構(gòu)造函數(shù)中添加了一個靜態(tài)方法,暫時稱為 withResolvers,該方法返回一個 Promise,并方便地公開其解決和拒絕函數(shù)。

const { promise, resolve, reject } = Promise.withResolvers();

源階段導(dǎo)入

無論是對于 JavaScript 還是 WebAssembly,都需要能夠更緊密地定制模塊的加載、鏈接和執(zhí)行,超出了標(biāo)準(zhǔn)的宿主執(zhí)行模型。

  • 對于 JavaScript,創(chuàng)建自定義加載器需要一種模塊源類型,以便共享宿主的解析、執(zhí)行、安全性和緩存語義。
  • 對于 WebAssembly,WebAssembly 模塊的導(dǎo)入和導(dǎo)出通常需要進行自定義的檢查和封裝,以便正確設(shè)置,這通常需要手動的獲取和實例化工作,在當(dāng)前的宿主 ESM 集成提案中沒有提供相應(yīng)支持。

通過將語法模塊源導(dǎo)入支持作為新的導(dǎo)入階段,可以創(chuàng)建一個基礎(chǔ)機制,將模塊的靜態(tài)、安全性和工具化優(yōu)勢從 ESM 集成擴展到這些動態(tài)實例化用例。

提案[3]允許ES模塊從主機提供的編譯后的模塊源的反映表達式進行導(dǎo)入:

import source x from "<specifier>";

僅支持上述形式的導(dǎo)入,不支持命名導(dǎo)出和未綁定聲明。

動態(tài)形式使用 import.<phase>:

const x = await import.source("<specifier>");

通過將階段作為顯式語法的一部分,可以在靜態(tài)上下文中靜態(tài)區(qū)分全動態(tài)導(dǎo)入和僅用于源的導(dǎo)入(無需處理依賴項)。

處理時間區(qū)域規(guī)范化的變化

ECMAScript中的時間區(qū)域依賴于IANA時區(qū)數(shù)據(jù)庫(TZDB)的標(biāo)識符,如America/Los_Angeles或Asia/Tokyo。該提案旨在改善開發(fā)人員在TZDB中更改時間區(qū)域的規(guī)范標(biāo)識符(例如從Europe/Kiev到Europe/Kyiv)時的開發(fā)體驗。

減少實現(xiàn)之間以及實現(xiàn)與規(guī)范之間的差異

  1. 已完成 - 簡化處理時區(qū)標(biāo)識符的抽象操作。
  2. 已完成 - 澄清規(guī)范以防止更多的分歧。
  3. 在 Temporal 廣泛采用之前,幫助V8和WebKit更新13個過時的規(guī)范標(biāo)識(如Asia/Calcutta,Europe/Kiev和Asia/Saigon),以免出現(xiàn)問題。
  4. 制定規(guī)范文本以減少實現(xiàn)之間的分歧。這一步需要在實現(xiàn)者和TG2(ECMA-402團隊)之間找到共同點,討論規(guī)范化應(yīng)該如何工作。

減少標(biāo)準(zhǔn)化變化的影響

  1. 避免對鏈接進行可觀察的跟隨。如果標(biāo)準(zhǔn)化變化不會影響現(xiàn)有代碼,那么未來的標(biāo)準(zhǔn)化變化就不太可能破壞Web。由于標(biāo)準(zhǔn)化是實現(xiàn)定義的,這個變化(或許會、也許不會;需要進一步研究)在Temporal第4階段之后發(fā)布可能是安全的,但最好不要等太久。
Temporal.TimeZone.from('Asia/Calcutta');
// => Asia/Kolkata(Firefox上當(dāng)前的Temporal行為)
// => Asia/Calcutta(建議:在將標(biāo)識符返回給調(diào)用方時,不要遵循鏈接)
  1. 添加Temporal.TimeZone.prototype.equals方法。由于(5)會在創(chuàng)建TimeZone對象時停止標(biāo)準(zhǔn)化標(biāo)識符,因此有一個直觀的方法來判斷兩個 TimeZone 對象是否表示相同的時區(qū)。
// 更人性化的標(biāo)準(zhǔn)化相等性測試
Temporal.TimeZone.from('Asia/Calcutta').equals('Asia/Kolkata');
// => true

Stage 2

Time Zone Canonicalization[4]

JavaScript應(yīng)用程序可能會變得非常龐大,以至于即使加載它們的初始化腳本,執(zhí)行起來也會產(chǎn)生顯著的性能開銷。通常,這種情況發(fā)生在應(yīng)用程序的生命周期較晚的階段,往往需要進行大規(guī)模的改動以提高性能。加載性能是一個重要的改進領(lǐng)域,涉及預(yù)加載技術(shù)以避免瀑布效應(yīng),并使用動態(tài)導(dǎo)入進行模塊的惰性加載。

盡管使用了這些技術(shù)解決了加載性能問題,但代碼本身的編寫方式仍會導(dǎo)致執(zhí)行性能開銷和CPU瓶頸在初始化過程中出現(xiàn)。

提案[5]是引入一種新的導(dǎo)入語法形式,它將始終返回一個命名空間對象。在使用時,模塊及其依賴項不會被執(zhí)行,但會完全加載到可以執(zhí)行的狀態(tài),然后才會認(rèn)為模塊圖已加載完成。只有當(dāng)訪問該模塊的屬性時,才會執(zhí)行相應(yīng)的操作。

該API將使用以下語法:

// 或使用自定義關(guān)鍵字: 
import defer * as yNamespace from "y";

Stage 1

DataView get/set Uint8Clamped 方法

現(xiàn)在只有其中 10 個具有DataView的 get/set 方法。

該提案[6]旨在添加DataView.prototype.getUint8Clamped和DataView.prototype.setUint8Clamped方法。

  • getUint8Clamped(offset: number): number:從指定的偏移量讀取一個8位無符號整數(shù)(Uint8Clamped)值,并返回該值。
  • setUint8Clamped(offset: number, value: number): void:將一個8位無符號整數(shù)(Uint8Clamped)值寫入到指定的偏移量。

可選鏈賦值

該提案[7]建議在賦值運算符左側(cè)添加對可選鏈的支持:a?.b = c。在實際開發(fā)中,經(jīng)常需要對對象的屬性進行賦值,但前提是該對象確實存在。

通常的做法是使用if語句來保護賦值操作:

if (obj) {
  obj.prop = value;
}

新語法和現(xiàn)有語法對比如下:

相關(guān)鏈接

[1]提案: https://github.com/tc39/proposal-array-grouping。

[2]Promise.withResolvers: https://github.com/tc39/proposal-promise-with-resolvers。

[3]提案: https://github.com/tc39/proposal-source-phase-imports。

[4]Time Zone Canonicalization: https://github.com/tc39/proposal-canonical-tz。

[5]提案: https://github.com/tc39/proposal-defer-import-eval。

[6]提案: https://github.com/tc39/proposal-dataview-get-set-uint8clamped。

[7]提案: https://github.com/tc39/proposal-optional-chaining-assignment。

責(zé)任編輯:姜華 來源: 前端充電寶
相關(guān)推薦

2009-09-25 09:27:33

Ubuntu 2010最新進展Lucid Lynx

2012-11-19 10:50:39

思杰CloudStack開源

2012-11-19 10:37:57

思杰OpenStack

2015-11-12 09:27:13

C++最新進展

2021-09-14 10:03:35

RustLinux開發(fā)工作

2020-07-02 16:00:53

?Flutter桌面應(yīng)用代碼

2021-09-16 10:15:56

Linux內(nèi)核Rust

2023-04-06 07:30:02

2009-03-23 08:44:29

Windows Ser微軟操作系統(tǒng)

2023-04-19 20:30:49

Rust商標(biāo)政策

2014-06-17 09:58:15

容器Google

2012-02-09 09:49:48

2013-04-09 17:27:19

GMIC球移動互聯(lián)網(wǎng)大會

2023-04-26 16:38:08

2021-06-15 14:54:23

ReactReact 18SSR

2024-06-27 11:02:44

2023-04-17 19:12:19

2020-09-23 22:33:28

量子芯片網(wǎng)絡(luò)
點贊
收藏

51CTO技術(shù)棧公眾號