<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關鍵字專題1關鍵字專題50關鍵字專題500關鍵字專題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關鍵字專題關鍵字專題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
        當前位置: 首頁 - 科技 - 知識百科 - 正文

        Node.js學習教程之Module模塊

        來源:懂視網 責編:小采 時間:2020-11-27 21:51:29
        文檔

        Node.js學習教程之Module模塊

        Node.js學習教程之Module模塊:前言 采用了 Commonjs 規范,通過 module.exports、require 來導出和導入模塊。模塊加載機制中,采用了延遲加載的策略。就是說在用到的情況下,系統模塊才會被加載,等加載完成后會放到 binding_cache 中。 分類(模塊類型) 系統模塊 核心模塊(n
        推薦度:
        導讀Node.js學習教程之Module模塊:前言 采用了 Commonjs 規范,通過 module.exports、require 來導出和導入模塊。模塊加載機制中,采用了延遲加載的策略。就是說在用到的情況下,系統模塊才會被加載,等加載完成后會放到 binding_cache 中。 分類(模塊類型) 系統模塊 核心模塊(n

        前言

        采用了 Commonjs 規范,通過 module.exports、require 來導出和導入模塊。模塊加載機制中,采用了延遲加載的策略。就是說在用到的情況下,系統模塊才會被加載,等加載完成后會放到 binding_cache 中。

        分類(模塊類型)

        系統模塊

      1. 核心模塊(native 模塊),http、buffer、fs 等,底層調用的內建模塊 (C/C++);
      2. C/C++ 模塊(built-in 內建模塊),供 native 模塊調用;
      3. 第三方模塊

      4. 第三方維護的模塊,比如 express、koa、moment.js 等;
      5. 本地維護的模塊(以路徑形式的文件模塊)比如 .、..、/ 開頭的;
      6. 文件形式

      7. javaScript 模塊,module.js;
      8. json 模塊,module.json;
      9. C/C++ 模塊,編譯后擴展名為 .node,module.node;
      10. 加載機制

        加載步驟

        經歷 路徑分析、文件定位和編譯執行。

        加載順序

        1. 系統緩存,一個模塊被執行后會被緩存起來,提高再次加載速度;
        2. 系統模塊,即原生模塊,部分核心模塊已經被編譯成二進制,省略了 路徑分析、文件定位,會直接被加載到了內存中,其中系統模塊定義在源碼的 lib 目錄下;
        3. 文件模塊,優先加載 .、..、/ 開頭的,會依次按照 .js、.json、.node 進行擴展名補足嘗試(文件沒有加上擴展名),最好還是加上文件的擴展名。
        4. 目錄模塊,文件模塊加載過程中,沒有找到,但發現一個同樣的目錄名,就會將這個目錄當作一個包來處理。這塊采用了 Commonjs 規范,在文件 package.json 中查找;
        5. node_module 模塊,如果系統模塊、路徑文件模塊都找不到,Node.js 會從當前模塊的父目錄開始查找,直到系統的根目錄;


        關于緩存問題

        模塊緩存后,可以通過 require.cache 查看已緩存的模塊。

        // 模塊文件 require.module.js
        module.exports = {
         name: 'pr',
         say(){ }
        }
        // 引用模塊文件 require.cache.js
        require('./require.module');
        
        console.log('require.cache ----- ');
        console.log(require.cache);

        對象引用

        1.exports 與 module.exports 關系

        const exports = module.exports;

        所以就不能改變 exports 的指向,可以這樣

        exports.info = {
         name: 'pr',
         age: 30
        }
        
        module.exports = {
         name: 'pr',
         age: 30
        }

        模塊循環引用

        模塊 moduleA.js 和 moduleB.js 兩個模塊互相引用,會怎樣?

        // moduleA.js
        console.log('模塊 moduleA');
        exports.name = 'moduleA name';
        
        age = 27;
        
        const moduleB = require('./moduleB.js');
        console.log('moduleA require moduleB =>', moduleB.name);
        // moduleB.js
        console.log('模塊 moduleB');
        exports.name = 'moduleB name';
        
        const moduleA = require('./moduleA.js');
        console.log('moduleB require moduleA =>', moduleA.name);

      11. 啟動模塊 node moduleA.js,會打印 模塊 moduleA;
      12. 模塊 moduleA.js 中加載 moduleB.js,打印 模塊 moduleB;
      13. 模塊 moduleB.js 中又加載 moduleA.js,此時模塊 moduleA.js 還沒有執行完,返回模塊 moduleA.js 的 exports 對象給到模塊 moduleB.js;
      14. 模塊 moduleB.js 加載完后,其中有個 moduleA.js 中掛載了全局的變量 age,所以能打印出來,最后將模塊 moduleB.js 的 exports 對象給到模塊 moduleA.js;
      15. 很有意思的是,在代碼執行前,會用一個封裝器將執行代碼段封裝起來

        (function(exports, require, module, __filename, __dirname) {
         // something
        });

        本次代碼 Github

        總結

        聲明:本網頁內容旨在傳播知識,若有侵權等問題請及時與本網聯系,我們將在第一時間刪除處理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

        文檔

        Node.js學習教程之Module模塊

        Node.js學習教程之Module模塊:前言 采用了 Commonjs 規范,通過 module.exports、require 來導出和導入模塊。模塊加載機制中,采用了延遲加載的策略。就是說在用到的情況下,系統模塊才會被加載,等加載完成后會放到 binding_cache 中。 分類(模塊類型) 系統模塊 核心模塊(n
        推薦度:
        標簽: 教程 js 模塊
        • 熱門焦點

        最新推薦

        猜你喜歡

        熱門推薦

        專題
        Top
        主站蜘蛛池模板: 国产亚洲玖玖玖在线观看| 亚洲精品人成电影网| 日韩一级免费视频| 妞干网免费视频在线观看| 国产网站免费观看| 国产亚洲美女精品久久久| 亚洲av午夜成人片精品网站 | 久久亚洲精品中文字幕三区| 日韩精品一区二区亚洲AV观看| 亚洲av无码一区二区三区观看| 亚洲av无码专区在线电影天堂| 日亚毛片免费乱码不卡一区| 99久久免费观看| 曰批全过程免费视频在线观看| 内射无码专区久久亚洲| 亚洲成a人片77777老司机| 美女的胸又黄又www网站免费| 国产精品网站在线观看免费传媒| 麻豆精品国产免费观看| 久久亚洲AV成人无码国产| 99久久久精品免费观看国产 | 日本免费大黄在线观看| 亚洲色图黄色小说| 国产成年无码久久久免费| 卡1卡2卡3卡4卡5免费视频| 久久久久亚洲精品无码网址色欲| 亚洲成a人片在线观看久| 亚洲人成网站日本片| 91精品国产免费久久国语麻豆| 免费一级毛片一级毛片aa| 亚洲香蕉在线观看| 中文字幕亚洲免费无线观看日本 | 久久久国产精品福利免费| 亚洲第一香蕉视频| 青青草国产免费久久久91| a级毛片免费观看在线| 在线免费观看国产视频| 三级网站免费观看| 美腿丝袜亚洲综合| 99久久久国产精品免费无卡顿| 国产91成人精品亚洲精品|