欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

原生JS以后也支持類型注解意義

 更新時(shí)間:2022年07月12日 09:54:46   作者:卡頌  
這篇文章主要為大家介紹了原生JS以后也支持類型注解意義,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

引言

在布達(dá)佩斯2022 JSConf會(huì)議上,tc39(ES標(biāo)準(zhǔn)委員會(huì))成員Gil Tayar介紹了一份當(dāng)前仍處于stage 1階段的提案 —— Type Annotations,意在讓原生JS支持類型注解。

換句話說(shuō),如果提案通過(guò),很多.ts文件將后綴改為.js后就能直接在瀏覽器中運(yùn)行。

一份tc39提案通常會(huì)經(jīng)歷5個(gè)階段:

  • stage 0:被提出
  • stage 1:接受審議
  • stage 2:規(guī)范基本完成
  • stage 3:等待被實(shí)現(xiàn)
  • stage 4:納入語(yǔ)言標(biāo)準(zhǔn)中

所以Type Annotations當(dāng)前仍處于接受審議的狀態(tài)。

但是提案發(fā)起者Gil Tayar對(duì)這份提案的通過(guò)很有信心,本文我們來(lái)聊聊這份提案的相關(guān)內(nèi)容。

為什么需要原生類型注解?

根據(jù)20年、21年state of JS的統(tǒng)計(jì),靜態(tài)類型高票當(dāng)選JS中當(dāng)前最欠缺的功能。

同時(shí),在Github報(bào)告中,TS被列為第四大最常用的語(yǔ)言

所以,對(duì)前端工程師來(lái)說(shuō),類型注解需求很大。

那么,既然已經(jīng)有了TS,為什么還需要原生JS支持類型注解呢?

通常來(lái)說(shuō),從開發(fā)者編寫的源代碼線上生產(chǎn)環(huán)境代碼間需要經(jīng)過(guò)代碼編譯。

代碼編譯主要包括兩個(gè)步驟:

  • 降級(jí)編譯(包括高級(jí)語(yǔ)法轉(zhuǎn)換為低級(jí)語(yǔ)法,高級(jí)方法的polyfill
  • 代碼轉(zhuǎn)譯(比如壓縮、混淆、tree-shaking、類型擦除)

所謂類型擦除,是指擦除代碼中的類型注解,讓其變成符合原生JS規(guī)范的代碼,比如:

// 擦除前
function add(a: number, b: number): number {
  return a + b;
}
// 擦除后
function add(a, b) {
  return a + b;
}

隨著時(shí)間的推移,各主流瀏覽器兼容性越來(lái)越好,步驟1在可預(yù)見的未來(lái)重要性會(huì)逐漸降低。

對(duì)于TS開發(fā)者,從源代碼線上生產(chǎn)環(huán)境代碼間可能只需要類型擦除。

如果原生JS支持類型注解,就能省去類型擦除對(duì)應(yīng)的編譯流程,讓代碼更容易在宿主環(huán)境執(zhí)行。

和TS的關(guān)系

這份提案的目的,并不是另起爐灶,獨(dú)立實(shí)現(xiàn)一套原生JS的類型注解。而是與TS團(tuán)隊(duì)合作,提出一套合適的規(guī)范。

新的規(guī)范與TS規(guī)范的關(guān)系類似下圖:

一方面,Type Annotations提案從TS中借鑒了很多特性,這就是圖中相交的部分。

你可以到grammar-conventions看到規(guī)范當(dāng)前定義的類型

另一方面,TS迭代速度很快,新的特性產(chǎn)出很快。而Type Annotations作為JS語(yǔ)言的一部分,迭代會(huì)更加保守,所以TS中一些特性在Type Annotations中并不支持。

此外,TS中一些結(jié)構(gòu)(比如EnumsNamespaces)存在運(yùn)行時(shí)的語(yǔ)義,Type Annotations也不會(huì)支持。

這些就是TS中存在,而Type Annotations中不存在的部分。

最后,Type Annotations設(shè)計(jì)的初衷并不是與TS強(qiáng)綁定,而僅僅是提供一套類型規(guī)范,開發(fā)者編寫代碼時(shí)的類型檢查還是由各種類型檢查器(比如TS、Flow)實(shí)現(xiàn)。

所以,Type Annotations還有一部分特性是TS當(dāng)前未定義的,這也是為了規(guī)范更廣泛的適用性考慮的,也就是圖中Type Annotations存在,而TS不存在的部分。

這部分特性需要TS后續(xù)實(shí)現(xiàn),這也是為什么Type Annotations要與TS團(tuán)隊(duì)合作的一大原因。

對(duì)開發(fā)者意味著什么

如果Type Annotations最終出現(xiàn)在ES20xx版中,屆時(shí)開發(fā)者編寫代碼的步驟是:

  • 選擇合適的類型檢查器(比如TS),這個(gè)類型檢查器需要完全遵循Type Annotations規(guī)范(而不是自己的規(guī)范,比如TS規(guī)范)
  • 編寫帶類型聲明的原生JS代碼
  • 類型檢查器會(huì)檢查類型錯(cuò)誤,并給予報(bào)錯(cuò)或提示

對(duì)于如下原生JS代碼,如果開發(fā)者傳入了錯(cuò)誤的類型,JS會(huì)報(bào)錯(cuò)么?

function add(a: number, b: number): number {
  return a + b;
}
// 錯(cuò)誤的類型傳參
add('KaSong', 123);

答案是:不會(huì)。

Type Annotations僅僅是一套規(guī)范,該規(guī)范由各種類型檢查器執(zhí)行。

JS的宿主環(huán)境(比如瀏覽器)在執(zhí)行帶類型聲明的JS代碼時(shí),會(huì)忽略類型聲明。

總結(jié)

有同學(xué)可能會(huì)問(wèn):就為了減少編譯時(shí)類型擦除這一步,就提出原生類型規(guī)范,有必要么?

甚至當(dāng)Type Annotations落地后,開發(fā)者上線前在進(jìn)行代碼壓縮時(shí),類型擦除也會(huì)作為代碼壓縮的職責(zé)之一。

從這個(gè)角度看,甚至沒(méi)有減少編譯時(shí)的工作量。

所以提出原生的類型規(guī)范,有必要么?

前端的發(fā)展實(shí)際是一個(gè)努力去編譯時(shí)流程的過(guò)程。

比如,編譯時(shí)代碼需要降級(jí),需要polyfill?隨著IE11停止服務(wù),主流瀏覽器紛紛跟進(jìn)標(biāo)準(zhǔn)落地,降級(jí)與polyfill的需求逐漸變少。

再比如,代碼需要打包?隨著ESM規(guī)范落地,在當(dāng)前,至少在開發(fā)環(huán)境中代碼已經(jīng)不需要打包(使用Vite)。

Type Annotations的出現(xiàn),就是遵循努力去編譯時(shí)流程這一趨勢(shì)的產(chǎn)物。

從這個(gè)角度看,還是很有必要的。

以上就是原生JS以后也支持類型注解意義的詳細(xì)內(nèi)容,更多關(guān)于原生JS支持類型注解的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JS前端使用canvas實(shí)現(xiàn)擴(kuò)展物體類和事件派發(fā)

    JS前端使用canvas實(shí)現(xiàn)擴(kuò)展物體類和事件派發(fā)

    這篇文章主要為大家介紹了JS前端使用canvas實(shí)現(xiàn)擴(kuò)展物體類和事件派發(fā)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-08-08
  • 微信小程序 簡(jiǎn)單教程實(shí)例詳解

    微信小程序 簡(jiǎn)單教程實(shí)例詳解

    這篇文章主要介紹了微信小程序 簡(jiǎn)單教程實(shí)例詳解的相關(guān)資料,這里對(duì)開發(fā)微信小程序步驟做了一一詳解,需要的朋友可以參考下
    2017-01-01
  • 微信小程序 地圖(map)實(shí)例詳解

    微信小程序 地圖(map)實(shí)例詳解

    這篇文章主要介紹了微信小程序 地圖(map)實(shí)例詳解的相關(guān)資料,這里對(duì)微信小程序的地圖API 進(jìn)行了詳細(xì)介紹并附示例代碼和實(shí)現(xiàn)效果圖,需要的朋友可以參考下
    2016-11-11
  • 微信小程序 canvas API詳解及實(shí)例代碼

    微信小程序 canvas API詳解及實(shí)例代碼

    這篇文章主要介紹了微信小程序 canvas API詳解及實(shí)例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-10-10
  • 8個(gè)工程必備的JavaScript代碼片段

    8個(gè)工程必備的JavaScript代碼片段

    這篇文章小編主要給大家介紹是8個(gè)工程中必須必備的JavaScript代碼片段,需要的小伙伴可以參考下面文章的具體內(nèi)容,對(duì)你有用的話建議收藏哦
    2021-09-09
  • 微信小程序 獲取相冊(cè)照片實(shí)例詳解

    微信小程序 獲取相冊(cè)照片實(shí)例詳解

    這篇文章主要介紹了微信小程序 獲取相冊(cè)照片實(shí)例詳解的相關(guān)資料,需要的朋友可以參考下
    2016-11-11
  • 微信小程序 動(dòng)畫的簡(jiǎn)單實(shí)例

    微信小程序 動(dòng)畫的簡(jiǎn)單實(shí)例

    這篇文章主要介紹了微信小程序 動(dòng)畫的簡(jiǎn)單實(shí)例的相關(guān)資料,希望通過(guò)本文能幫助到大家,需要的朋友可以參考下
    2017-10-10
  • js前端埋點(diǎn)監(jiān)控解析

    js前端埋點(diǎn)監(jiān)控解析

    本文針對(duì)埋點(diǎn)系統(tǒng)和監(jiān)控系統(tǒng)的融合的一點(diǎn)進(jìn)行簡(jiǎn)單的介紹與探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • 最新評(píng)論