首頁 >web前端 >前端問答 >es模組能在node中執行嗎

es模組能在node中執行嗎

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB原創
2022-07-04 17:08:211792瀏覽

es模組能在node中執行;node從8.5.2版本開始就支援原生es模組,可以透過命令列選項開啟功能,es模組也即ECMAScript模組,是一種JavaScript程式碼重複使用機制,但是不能在es模組中使用require()。

es模組能在node中執行嗎

本文操作環境:Windows10系統、nodejs 12.19.0版、Dell G3電腦。

es模組能在node中執行

從版本 8.5.0 開始,Node.js 開始支援原生 ES 模組,可以透過命令列選項開啟功能。新功能很大程度得歸功於 Bradley Farias。

1.示範

這個範例的程式碼目錄結構如下:

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

執行示範:

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

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

ES 模組:

·不能動態匯入模組。但是 動態import() 的相關工作正在進行中,應該很快就能提供支援。

·沒有元變量,如 __dirname 和 __filename。但是,有一個的類似功能的提案:「import.meta」。看起來可能是這樣:

console.log(import.meta.url);

·現在所有模組標識符都是URL(這部分在Node.js 是新增的) :

·檔案- 帶有檔案副檔名的相對路徑: ../util/tools.mjs

·庫- 沒有檔案副檔名,也沒有路徑lodash

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

與 CJS 模組的互通性

你可以匯入 CJS 模組,但它們總是只有預設的匯出 - 即 module.exports 的值。讓 CJS 模組支援命名導出已經在做了,但可能需要一段時間。如果你能幫忙,可以來做。

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。而且,它的標識符始終是 URL 也會導致一些細微差異。

 · ES 模組始終以非同步方式加載,這確保了與 Web 的最大相容性。這種載入風格並不能透過 require() 混合使用同步載入 CJS 模組。

 · 禁止同步模組載入也可以為 Top-level await 導入 ES 模組保留後路(一個目前正在考慮的功能)。

推薦學習:《nodejs影片教學

以上是es模組能在node中執行嗎的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn