成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

webpack把你的項(xiàng)目編譯成了什么

cheukyin / 516人閱讀

摘要:一般會(huì)幫我們把所有的文件,,圖片等編譯成一個(gè)文件安裝,使用,一般這個(gè)文件名為。當(dāng)被加載到瀏覽器這個(gè)函數(shù)就會(huì)立即執(zhí)行。模塊緩存模塊緩存所有被加載過(guò)的模塊都會(huì)成為對(duì)象的屬性。這一步主要是靠函數(shù)做到的。

webpack一般會(huì)幫我們把所有的文件(js,css,圖片等)編譯成一個(gè)js文件(webpack安裝,使用),一般這個(gè)文件名為bundle.js。我們直接在html文件中用script標(biāo)簽引入就行了,就想下面這樣:


    
        
    
    
        
    
 

那bundle.js文件如何組織我們的資源文件的呢,我們下面通過(guò)一個(gè)例子看一下

創(chuàng)建entry.js文件

module.exports = "我是入口js!";

運(yùn)行下面命令

webpack ./entry.js bundle.js

會(huì)生成bundle.js文件

/******/ (function(modules) { // webpackBootstrap
/******/     // The module cache  模塊緩存
/******/     var installedModules = {};

/******/     // The require function  加載方法
/******/     function __webpack_require__(moduleId) {

/******/         // Check if module is in cache  檢查模塊是否在緩存中
/******/         if(installedModules[moduleId])
/******/             return installedModules[moduleId].exports;

/******/         // Create a new module (and put it into the cache)  創(chuàng)建一個(gè)新模塊放到緩存中
/******/         var module = installedModules[moduleId] = {
/******/             exports: {},
/******/             id: moduleId,
/******/             loaded: false
/******/         };

/******/         // Execute the module function  執(zhí)行模塊方法
/******/         modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);

/******/         // Flag the module as loaded 標(biāo)記已被加載的模塊
/******/         module.loaded = true;

/******/         // Return the exports of the module 返回模塊的輸出
/******/         return module.exports;
/******/     }


/******/     // expose the modules object (__webpack_modules__)
/******/     __webpack_require__.m = modules;

/******/     // expose the module cache
/******/     __webpack_require__.c = installedModules;

/******/     // __webpack_public_path__
/******/     __webpack_require__.p = "";

/******/     // Load entry module and return exports
/******/     return __webpack_require__(0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ function(module, exports) {

    module.exports = "我是入口js!";



/***/ }
/******/ ]);
立即調(diào)用的函數(shù)表達(dá)式(Immediately-Invoked Function Expression)

其實(shí)bundle.js文件里就是一個(gè)立即調(diào)用的函數(shù)表達(dá)式(Immediately-Invoked Function Expression)像下面這樣:

(function(/*parameter*/){
          /* code */
})(/*argument*/)

這個(gè)函數(shù)里定義了一個(gè)變量installedModules和一個(gè)函數(shù)function __webpack_require__(moduleId)。當(dāng)bundle.js被加載到瀏覽器這個(gè)函數(shù)就會(huì)立即執(zhí)行。

模塊緩存 installedModules
// The module cache  模塊緩存
var installedModules = {};

所有被加載過(guò)的模塊都會(huì)成為installedModules對(duì)象的屬性。這一步主要是靠函數(shù)__webpack_require__做到的。

加載方法 webpack_require
// The require function  加載方法
function __webpack_require__(moduleId) {
 // Check if module is in cache  檢查模塊是否在緩存中
       if(installedModules[moduleId])
            return installedModules[moduleId].exports;

        // Create a new module (and put it into the cache)  創(chuàng)建一個(gè)新模塊放到緩存中
        var module = installedModules[moduleId] = {
            exports: {},
           id: moduleId,
            loaded: false
        };

        // Execute the module function  執(zhí)行模塊方法
        modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);

        // Flag the module as loaded 標(biāo)記已被加載的模塊
        module.loaded = true;

        // Return the exports of the module 返回模塊的輸出
        return module.exports;
  }

文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/111239.html

相關(guān)文章

  • webpack你的項(xiàng)目編譯成了什么

    摘要:一般會(huì)幫我們把所有的文件,,圖片等編譯成一個(gè)文件安裝,使用,一般這個(gè)文件名為。當(dāng)被加載到瀏覽器這個(gè)函數(shù)就會(huì)立即執(zhí)行。模塊緩存模塊緩存所有被加載過(guò)的模塊都會(huì)成為對(duì)象的屬性。這一步主要是靠函數(shù)做到的。 webpack一般會(huì)幫我們把所有的文件(js,css,圖片等)編譯成一個(gè)js文件(webpack安裝,使用),一般這個(gè)文件名為bundle.js。我們直接在html文件中用script標(biāo)簽引...

    yearsj 評(píng)論0 收藏0
  • webpack你的項(xiàng)目編譯成了什么

    摘要:一般會(huì)幫我們把所有的文件,,圖片等編譯成一個(gè)文件安裝,使用,一般這個(gè)文件名為。當(dāng)被加載到瀏覽器這個(gè)函數(shù)就會(huì)立即執(zhí)行。模塊緩存模塊緩存所有被加載過(guò)的模塊都會(huì)成為對(duì)象的屬性。這一步主要是靠函數(shù)做到的。 webpack一般會(huì)幫我們把所有的文件(js,css,圖片等)編譯成一個(gè)js文件(webpack安裝,使用),一般這個(gè)文件名為bundle.js。我們直接在html文件中用script標(biāo)簽引...

    1fe1se 評(píng)論0 收藏0
  • webpack初探

    摘要:我們還想要的顏色我們通過(guò)下面命令行可以做到觀察模式我們不想每一次項(xiàng)目變化都要手動(dòng)編譯可以緩存兩次編譯之間沒(méi)有變化的模塊和輸出文件。開(kāi)發(fā)服務(wù)器使用開(kāi)發(fā)服務(wù)器開(kāi)發(fā)體驗(yàn)會(huì)更好這將在本地啟動(dòng)一個(gè)端口的服務(wù),指向靜態(tài)文件以及自動(dòng)編譯。 原文英文版來(lái)自webpack官網(wǎng) demo代碼 本文地址 歡迎瀏覽 這是一篇通過(guò)一個(gè)小例子給你介紹webpack的文章 你可以通過(guò)這篇文章了解到: 如...

    soasme 評(píng)論0 收藏0
  • webpack初探

    摘要:我們還想要的顏色我們通過(guò)下面命令行可以做到觀察模式我們不想每一次項(xiàng)目變化都要手動(dòng)編譯可以緩存兩次編譯之間沒(méi)有變化的模塊和輸出文件。開(kāi)發(fā)服務(wù)器使用開(kāi)發(fā)服務(wù)器開(kāi)發(fā)體驗(yàn)會(huì)更好這將在本地啟動(dòng)一個(gè)端口的服務(wù),指向靜態(tài)文件以及自動(dòng)編譯。 原文英文版來(lái)自webpack官網(wǎng) demo代碼 本文地址 歡迎瀏覽 這是一篇通過(guò)一個(gè)小例子給你介紹webpack的文章 你可以通過(guò)這篇文章了解到: 如...

    Lavender 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<