摘要:一般會(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
摘要:一般會(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)簽引...
摘要:一般會(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)簽引...
摘要:我們還想要的顏色我們通過(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ò)這篇文章了解到: 如...
摘要:我們還想要的顏色我們通過(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ò)這篇文章了解到: 如...
閱讀 855·2023-04-25 21:21
閱讀 3237·2021-11-24 09:39
閱讀 3079·2021-09-02 15:41
閱讀 2009·2021-08-26 14:13
閱讀 1838·2019-08-30 11:18
閱讀 2785·2019-08-29 16:25
閱讀 517·2019-08-28 18:27
閱讀 1589·2019-08-28 18:17