溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

淺談Node新版本13.2.0正式支持ES Modules特性

發(fā)布時(shí)間:2020-10-19 00:47:27 來源:腳本之家 閱讀:205 作者:winty 欄目:web開發(fā)

在本月 21 日,即2019.11.21,Node.js 發(fā)布了 13.2.0 版本,更新了一些特性。其中最令人興奮的莫過于正式取消了 --experimental-modules 啟動參數(shù)。這說明Node.js 正式支持 ES modules。我們一起來看看。

Stability Index說明

Stability Index,即 Api 的穩(wěn)定指數(shù)說明。它包括3個(gè)值:

  1. Stability: 0 ,不推薦使用。表示該Api官方不推薦使用,該功能可能會發(fā)出警告。不能保證向后兼容。
  2. Stability: 1,實(shí)驗(yàn)性的。表示該Api已經(jīng)支持使用性使用。但是在將來的任何發(fā)行版中都可能發(fā)生非向后兼容的更改或刪除。不建議在生產(chǎn)環(huán)境中使用該功能。

Stability: 2,穩(wěn)定版。表示已經(jīng)試驗(yàn)完成,基本不會再發(fā)生改動,可以再生產(chǎn)環(huán)境中使用。

Unflag --experimental-modules

在 13.2.0的版本中,node 默認(rèn)情況下會啟用對ECMAScript模塊的實(shí)驗(yàn)支持,也就是不需要啟動參數(shù)了。那么nodejs是如何區(qū)分 esm 和 commonjs 的呢?這里翻譯一下官方文檔。
Node.js會將把以下內(nèi)容視為ES模塊:

  • 文件后綴為.mjs
  • 當(dāng)文件后綴為.js,或者無文件后綴時(shí),看其package.json文件,package.json 中 type 字段值為 "module"
  • 啟動參數(shù)添加 —-input-type=module
  • 使用傳遞字符參數(shù)給--eval,如$ node --eval 'import("http");

其他情況下,都會被識別為 commonjs?,F(xiàn)在node已經(jīng)支持esm和commonjs了,我們在使用的時(shí)候,最好還是指定一下模塊。

舉個(gè)例子🌰

import './legacy-file.cjs';
// Loaded as CommonJS since .cjs is always loaded as CommonJS.

import 'commonjs-package/src/index.mjs';
// Loaded as ES module since .mjs is always loaded as ES module.

這種情況,根據(jù)文件后綴按不同模塊處理。

// package.json
{
 "type": "module"
}

當(dāng)前目錄下,或者上級目錄中的package.json含有"type": "module"時(shí),該模塊會被當(dāng)作ES Module。

// my-app.js, in an ES module package scope because there is a package.json
// file in the same folder with "type": "module".

import './startup/init.js';
// Loaded as ES module since ./startup contains no package.json file,
// and therefore inherits the ES module package scope from one level up.

import 'commonjs-package';
// Loaded as CommonJS since ./node_modules/commonjs-package/package.json
// lacks a "type" field or contains "type": "commonjs".

import './node_modules/commonjs-package/index.js';
// Loaded as CommonJS since ./node_modules/commonjs-package/package.json
// lacks a "type" field or contains "type": "commonjs".

如上圖注釋所示,如果當(dāng)前文件目錄不包含package.json,則會看其父級目錄的package.json文件,然后判斷type類型。

node --input-type=module --eval "import { sep } from 'path'; console.log(sep);"
echo "import { sep } from 'path'; console.log(sep);" | node --input-type=module

這里就是使用傳遞字符參數(shù)給--eval,添加 --input-type啟動參數(shù)的情況。

快速體驗(yàn)

目前13.2.0版本的官方文檔對ES Module的標(biāo)記是 Stability: 1,你已經(jīng)可以安裝新版本來試驗(yàn)啦。相信在社區(qū)的共同努力下,很快就會進(jìn)入 Stability: 2 正式穩(wěn)定版了。

本地開發(fā)的時(shí)候,經(jīng)常需要快速更新或切換不同的node版本。可以使用 nvm、n 等方案,還有一個(gè)跨平臺的本地管理方案就是 nvs。都可以選擇使用,這里我舉的例子,就是使用 nvs:

$ nvs add node/13.2.0
$ nvs use 13.2.0
$ node -v
13.2.0

趕緊嘗試一下吧~

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持億速云。

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI