溫馨提示×

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

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

怎么在Node.js 中使用ES模塊

發(fā)布時(shí)間:2021-03-17 16:15:41 來(lái)源:億速云 閱讀:254 作者:Leah 欄目:web開發(fā)

怎么在Node.js 中使用ES模塊?相信很多沒有經(jīng)驗(yàn)的人對(duì)此束手無(wú)策,為此本文總結(jié)了問題出現(xiàn)的原因和解決方法,通過(guò)這篇文章希望你能解決這個(gè)問題。

1.演示

這個(gè)示例的代碼目錄結(jié)構(gòu)如下:

esm-demo/
 lib.mjs
 main.mjs

lib.mjs:

export function add(x, y) {
 return x + y;
}

main.mjs:

import {add} from './lib.mjs';
console.log('Result: '+add(2, 3));

運(yùn)行演示:

$ node --experimental-modules main.mjs
Result: 5

2.清單:需要注意的事情

ES 模塊:

·不能動(dòng)態(tài)導(dǎo)入模塊。但是 動(dòng)態(tài)import() 的相關(guān)工作正在進(jìn)行中,應(yīng)該很快就能提供支持。

·沒有元變量,如 __dirname 和 __filename。但是,有一個(gè)的類似功能的提案:“import.meta”??雌饋?lái)可能是這樣:

console.log(import.meta.url);

·現(xiàn)在所有模塊標(biāo)識(shí)符都是 URL(這部分在 Node.js 是新增的):

·文件 - 帶文件擴(kuò)展名的相對(duì)路徑: ../util/tools.mjs

·庫(kù) - 沒有文件擴(kuò)展名,也沒有路徑 lodash

·如何更好地使 npm 庫(kù)在瀏覽器中也可用(不使用 bundler)仍有待觀察。一種可能性是引入 RequireJS 風(fēng)格的配置數(shù)據(jù),將路徑映射到實(shí)際路徑。目前,在瀏覽器中使用 bare path 的模塊標(biāo)識(shí)符是非法的。

與 CJS 模塊的互操作性

你可以導(dǎo)入 CJS 模塊,但它們總是只有默認(rèn)的導(dǎo)出 - 即 module.exports 的值。讓 CJS 模塊支持命名導(dǎo)出已經(jīng)在做了,但可能需要一段時(shí)間。如果你能幫忙,可以來(lái)做。

import fs1 from 'fs';
console.log(Object.keys(fs1).length); // 86
import * as fs2 from 'fs';
console.log(Object.keys(fs2)); // ['default']

 · 不能在 ES 模塊中使用 require()。主要原因是:

 · 路徑解析工作稍有不同:ESM 不支持 NODE_PATH 和 require.extensions。而且,它的標(biāo)識(shí)符始終是 URL 也會(huì)導(dǎo)致一些細(xì)微差異。

 · ES 模塊始終以異步方式加載,這確保了與 Web 的最大兼容性。這種加載風(fēng)格并不能通過(guò) require() 混合使用同步加載 CJS 模塊。

 · 禁止同步模塊加載也可以為 Top-level await 導(dǎo)入 ES 模塊保留后路(一個(gè)當(dāng)前正在考慮的功能)。

3.早期版本的 Node.js 上的 ES 模塊

如果要在 8.5.0 之前的 Node.js 版本上使用 ES 模塊,請(qǐng)參閱 John-David Dalton 的 @std/esm。

提示:如果不啟用任何可解鎖的額外功能,將在 Node.js 保持 100% 兼容原生 ES 模塊.

看完上述內(nèi)容,你們掌握怎么在Node.js 中使用ES模塊的方法了嗎?如果還想學(xué)到更多技能或想了解更多相關(guān)內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道,感謝各位的閱讀!

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

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

AI