做爰高潮a片〈毛片〉,尤物av天堂一区二区在线观看,一本久久A久久精品VR综合,添女人荫蒂全部过程av

最新文章專題視頻專題問答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)前位置: 首頁(yè) - 科技 - 知識(shí)百科 - 正文

Node.js學(xué)習(xí)教程之Module模塊

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

Node.js學(xué)習(xí)教程之Module模塊

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

前言

采用了 Commonjs 規(guī)范,通過 module.exports、require 來導(dǎo)出和導(dǎo)入模塊。模塊加載機(jī)制中,采用了延遲加載的策略。就是說在用到的情況下,系統(tǒng)模塊才會(huì)被加載,等加載完成后會(huì)放到 binding_cache 中。

分類(模塊類型)

系統(tǒng)模塊

  • 核心模塊(native 模塊),http、buffer、fs 等,底層調(diào)用的內(nèi)建模塊 (C/C++);
  • C/C++ 模塊(built-in 內(nèi)建模塊),供 native 模塊調(diào)用;
  • 第三方模塊

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

  • javaScript 模塊,module.js;
  • json 模塊,module.json;
  • C/C++ 模塊,編譯后擴(kuò)展名為 .node,module.node;
  • 加載機(jī)制

    加載步驟

    經(jīng)歷 路徑分析、文件定位和編譯執(zhí)行。

    加載順序

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


    關(guān)于緩存問題

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

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

    對(duì)象引用

    1.exports 與 module.exports 關(guān)系

    const exports = module.exports;

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

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

    模塊循環(huán)引用

    模塊 moduleA.js 和 moduleB.js 兩個(gè)模塊互相引用,會(huì)怎樣?

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

  • 啟動(dòng)模塊 node moduleA.js,會(huì)打印 模塊 moduleA;
  • 模塊 moduleA.js 中加載 moduleB.js,打印 模塊 moduleB;
  • 模塊 moduleB.js 中又加載 moduleA.js,此時(shí)模塊 moduleA.js 還沒有執(zhí)行完,返回模塊 moduleA.js 的 exports 對(duì)象給到模塊 moduleB.js;
  • 模塊 moduleB.js 加載完后,其中有個(gè) moduleA.js 中掛載了全局的變量 age,所以能打印出來,最后將模塊 moduleB.js 的 exports 對(duì)象給到模塊 moduleA.js;
  • 很有意思的是,在代碼執(zhí)行前,會(huì)用一個(gè)封裝器將執(zhí)行代碼段封裝起來

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

    本次代碼 Github

    總結(jié)

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

    文檔

    Node.js學(xué)習(xí)教程之Module模塊

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

    最新推薦

    猜你喜歡

    熱門推薦

    專題
    Top
    主站蜘蛛池模板: 迁安市| 息烽县| 湖北省| 临武县| 章丘市| 淮北市| 株洲县| 红原县| 富宁县| 高台县| 阜宁县| 仙居县| 江阴市| 凉城县| 阿勒泰市| 曲周县| 买车| 天祝| 双柏县| 甘孜县| 偃师市| 缙云县| 横山县| 安宁市| 弋阳县| 阿城市| 通渭县| 大姚县| 开原市| 隆德县| 蒲江县| 霍山县| 康马县| 赣州市| 镇沅| 平远县| 台东市| 许昌市| 顺义区| 梧州市| 玉屏|