您好,登錄后才能下訂單哦!
怎么在Node.js 中使用ES模塊?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。
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 模塊保留后路(一個當前正在考慮的功能)。
3.早期版本的 Node.js 上的 ES 模塊
如果要在 8.5.0 之前的 Node.js 版本上使用 ES 模塊,請參閱 John-David Dalton 的 @std/esm。
提示:如果不啟用任何可解鎖的額外功能,將在 Node.js 保持 100% 兼容原生 ES 模塊.
看完上述內容,你們掌握怎么在Node.js 中使用ES模塊的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。