<span id="mktg5"></span>

<i id="mktg5"><meter id="mktg5"></meter></i>

        <label id="mktg5"><meter id="mktg5"></meter></label>
        最新文章專題視頻專題問答1問答10問答100問答1000問答2000關(guān)鍵字專題1關(guān)鍵字專題50關(guān)鍵字專題500關(guān)鍵字專題1500TAG最新視頻文章推薦1 推薦3 推薦5 推薦7 推薦9 推薦11 推薦13 推薦15 推薦17 推薦19 推薦21 推薦23 推薦25 推薦27 推薦29 推薦31 推薦33 推薦35 推薦37視頻文章20視頻文章30視頻文章40視頻文章50視頻文章60 視頻文章70視頻文章80視頻文章90視頻文章100視頻文章120視頻文章140 視頻2關(guān)鍵字專題關(guān)鍵字專題tag2tag3文章專題文章專題2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章專題3
        問答文章1 問答文章501 問答文章1001 問答文章1501 問答文章2001 問答文章2501 問答文章3001 問答文章3501 問答文章4001 問答文章4501 問答文章5001 問答文章5501 問答文章6001 問答文章6501 問答文章7001 問答文章7501 問答文章8001 問答文章8501 問答文章9001 問答文章9501
        當(dāng)前位置: 首頁 - 科技 - 知識百科 - 正文

        在 Node.js 中使用原生 ES 模塊方法解析

        來源:懂視網(wǎng) 責(zé)編:小采 時(shí)間:2020-11-27 22:29:37
        文檔

        在 Node.js 中使用原生 ES 模塊方法解析

        在 Node.js 中使用原生 ES 模塊方法解析:從版本 8.5.0 開始,Node.js 開始支持原生 ES 模塊,可以通過命令行選項(xiàng)打開該功能。新功能很大程度上得歸功于 Bradley Farias。 1.演示 這個(gè)示例的代碼目錄結(jié)構(gòu)如下: esm-demo/ lib.mjs main.mjs lib.mjs: export funct
        推薦度:
        導(dǎo)讀在 Node.js 中使用原生 ES 模塊方法解析:從版本 8.5.0 開始,Node.js 開始支持原生 ES 模塊,可以通過命令行選項(xiàng)打開該功能。新功能很大程度上得歸功于 Bradley Farias。 1.演示 這個(gè)示例的代碼目錄結(jié)構(gòu)如下: esm-demo/ lib.mjs main.mjs lib.mjs: export funct

        從版本 8.5.0 開始,Node.js 開始支持原生 ES 模塊,可以通過命令行選項(xiàng)打開該功能。新功能很大程度上得歸功于 Bradley Farias。

        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”。看起來可能是這樣:

        console.log(import.meta.url);

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

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

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

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

        與 CJS 模塊的互操作性

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

        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)識符始終是 URL 也會導(dǎo)致一些細(xì)微差異。

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

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

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

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

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

        FAQ

        什么時(shí)候可以不帶命令行選項(xiàng)使用ES 模塊?

        目前的計(jì)劃是在 Node.js 10 LTS 中默認(rèn)可使用 ES 模塊。

        進(jìn)一步閱讀

        有關(guān) Node.js 和瀏覽器中 ES 模塊的更多信息:

         · “Making transpiled ES modules more spec-compliant” [using ES modules natively vs. transpiling them via Babel]

         · “Module specifiers: what's new with ES modules?” [Why .mjs? How are module specifiers resolved? Etc.]

         · “Modules” [in-depth chapter on ES modules in “Exploring ES6”]

        即將到來的 ECMAScript 提案:

         · 博客: “ES proposal: import() – dynamically importing ES modules”

         · 提案: “import.meta”

        總結(jié)

        聲明:本網(wǎng)頁內(nèi)容旨在傳播知識,若有侵權(quán)等問題請及時(shí)與本網(wǎng)聯(lián)系,我們將在第一時(shí)間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        在 Node.js 中使用原生 ES 模塊方法解析

        在 Node.js 中使用原生 ES 模塊方法解析:從版本 8.5.0 開始,Node.js 開始支持原生 ES 模塊,可以通過命令行選項(xiàng)打開該功能。新功能很大程度上得歸功于 Bradley Farias。 1.演示 這個(gè)示例的代碼目錄結(jié)構(gòu)如下: esm-demo/ lib.mjs main.mjs lib.mjs: export funct
        推薦度:
        標(biāo)簽: 使用 模塊 es
        • 熱門焦點(diǎn)

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 中文字幕精品亚洲无线码二区| 成人久久久观看免费毛片| 99精品免费视品| 亚洲性猛交XXXX| 最近国语视频在线观看免费播放| 亚洲人成网站18禁止一区| 国产精品国产亚洲区艳妇糸列短篇 | 午夜视频在线在免费| 日日麻批免费40分钟日本的| 亚洲国产精品久久久久婷婷软件| 亚洲免费在线视频| 亚洲影院在线观看| 亚洲免费观看在线视频| 亚洲精品无码久久久久久久| 九九精品免费视频| 亚洲AV日韩综合一区| 免费成人黄色大片| 在线免费观看h片| 婷婷精品国产亚洲AV麻豆不片 | 亚洲天堂中文字幕在线观看| 免费精品国产自产拍在线观看图片| 亚洲男人天堂2022| 免费大黄网站在线观看| 中文字幕乱码一区二区免费| 亚洲精品福利网泷泽萝拉| 成人性生免费视频| 污网站在线免费观看| 亚洲AV无码乱码在线观看富二代| 真人做A免费观看| 美女裸体无遮挡免费视频网站| 中文字幕在亚洲第一在线| 69影院毛片免费观看视频在线 | 亚洲AV色吊丝无码| 免费中文字幕一级毛片| 在线观看免费播放av片| 亚洲久悠悠色悠在线播放| 爱情岛论坛网亚洲品质自拍| 亚洲视频在线免费播放| 日韩国产欧美亚洲v片 | 亚洲国产精品无码久久九九大片 | 亚洲无成人网77777|