摘要:打包入口模塊模塊打包結(jié)果打包結(jié)果是一個(gè)立即執(zhí)行函數(shù)表達(dá)式緩存所有模塊輸出的內(nèi)容檢查緩存中是否有該模塊,如果有則返回該模塊的如果沒有,則執(zhí)行下面的步驟運(yùn)行該模塊,并將模塊的輸出放置在緩存中創(chuàng)建一個(gè)新的模塊模塊的模塊的輸出是否加載到緩存中模塊的
打包入口
import {message, methods} from "./module01" const sayHello = require("./module02") function component() { sayHello() methods() var element = document.createElement("div"); element.innerHTML = message return element; } document.body.appendChild(component());
模塊1
const message = "hello world" console.log("this is module01") const methods = function(){ console.log("hello world") } export {message, methods}
模塊2
const sayHello = () => { console.log("hello world") } const sayBye = () => { console.log("Bye Bye") } console.log("this is module02") exports.sayHello = sayHello exports.sayHello = sayBye
打包結(jié)果
打包結(jié)果是一個(gè)立即執(zhí)行函數(shù)表達(dá)式
(function (modules) { // 緩存所有模塊”輸出“的內(nèi)容 var installedModules = {}; function __webpack_require__(moduleId) { /* *檢查緩存中是否有該模塊,如果有則返回該模塊的export *如果沒有,則執(zhí)行下面的步驟:運(yùn)行該模塊,并將模塊的”輸出“放置在緩存中 */ if (installedModules[moduleId]) { return installedModules[moduleId].exports; } // 創(chuàng)建一個(gè)新的模塊 var module = installedModules[moduleId] = { i: moduleId, // 模塊的id l: false, // 模塊的”輸出“是否加載到緩存中 exports: {} // 模塊的”輸出“ }; // 執(zhí)行對(duì)應(yīng)的模塊,并將模塊的”輸出“綁定到module.exports上 modules[moduleId].call(module.exports, module, module.exports, __webpack_require__); // 修改是否加載的標(biāo)識(shí) module.l = true; // 返回模塊的”輸出“ return module.exports; } // 所有的模塊 __webpack_require__.m = modules; // 所有被緩存的模塊 __webpack_require__.c = installedModules; // 定義一個(gè)getter方法 __webpack_require__.d = function (exports, name, getter) { // 如果一個(gè)對(duì)象沒有name對(duì)應(yīng)的屬性,則在該對(duì)象上定義該屬性 if (!__webpack_require__.o(exports, name)) { Object.defineProperty(exports, name, { configurable: false, enumerable: true, get: getter }); } }; // __webpack_require__.n = function (module) { var getter = module && module.__esModule ? function getDefault() { return module["default"]; } : function getModuleExports() { return module; }; __webpack_require__.d(getter, "a", getter); return getter; }; // 定義一個(gè)方法:判斷一個(gè)對(duì)象是否有某一屬性 __webpack_require__.o = function (object, property) { return Object.prototype.hasOwnProperty.call(object, property); }; // __webpack_public_path__ __webpack_require__.p = ""; // 從第一個(gè)模塊開始加載(執(zhí)行) return __webpack_require__(__webpack_require__.s = 0); })// 匿名函數(shù)定義結(jié)束 ([ /* 0:打包的起點(diǎn),起始模塊 */ (function (module, __webpack_exports__, __webpack_require__) { // 由于該模塊使用了ES6語法import,所以需要在“輸出”的對(duì)象上定義 __esModule屬性 "use strict"; Object.defineProperty(__webpack_exports__, "__esModule", { value: true }); /* 表明模塊1是通過ES6語法來導(dǎo)入的 */ var __WEBPACK_IMPORTED_MODULE_0__module01__ = __webpack_require__(1); // 表明模塊2是通過CommonJS語法來導(dǎo)入的 const sayHello = __webpack_require__(2) function component() { sayHello() // 調(diào)用模塊1輸出的b方法 Object(__WEBPACK_IMPORTED_MODULE_0__module01__["b"])() var element = document.createElement("div"); // 使用模塊1輸出的a屬性 element.innerHTML = __WEBPACK_IMPORTED_MODULE_0__module01__["a"] return element; } document.body.appendChild(component()); /***/ }), /* 1 */ (function (module, __webpack_exports__, __webpack_require__) { // 當(dāng)前模塊是通過ES6語法來導(dǎo)入/輸出模塊的 "use strict"; /* 根據(jù)順序,將當(dāng)前模塊輸出定義在 __webpack_exports__上 */ __webpack_require__.d(__webpack_exports__, "a", function () { return message; }); /* harmony export (binding) */ __webpack_require__.d(__webpack_exports__, "b", function () { return methods; }); const message = "hello world" console.log("this is module01") const methods = function () { console.log("hello world") } }), /* 2 */ (function (module, exports) { const sayHello = () => { console.log("hello world") } const sayBye = () => { console.log("Bye Bye") } console.log("this is module02") // 模塊2是通過CommonJS的方式輸出的,所以直接在exports上添加“輸出”結(jié)果 exports.sayHello = sayHello exports.sayHello = sayBye /***/ }) ]);
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://www.ezyhdfw.cn/yun/92170.html
摘要:安裝要開始使用在項(xiàng)目中進(jìn)行開發(fā)前我們首先需要在全局環(huán)境中進(jìn)行安裝。使用它可以將的語法轉(zhuǎn)換為的語法,以便在現(xiàn)在有的環(huán)境執(zhí)行。,是一段正則,表示進(jìn)行匹配的資源類型。為指定應(yīng)該被忽略的文件,我們?cè)谶@兒指定了。 1.認(rèn)識(shí)Webpack 構(gòu)建應(yīng)用前我們先來了解一下Webpack, Webpack是一個(gè)模塊打包工具,能夠把各種文件(例如:ReactJS、Babel、Coffeescript、Les...
摘要:了解什么是官方文檔是這樣介紹的點(diǎn)我了解官方文檔簡單的來說,可以看做是模塊打包機(jī)它做的事情是,分析你的項(xiàng)目結(jié)構(gòu),找到模塊以及其它的一些瀏覽器不能直接運(yùn)行的拓展語言,等,并將其轉(zhuǎn)換和打包為合適的格式供瀏覽器使用。 了解webpack 什么是webpack 官方文檔是這樣介紹的:點(diǎn)我了解官方文檔 簡單的來說,WebPack可以看做是模塊打包機(jī):它做的事情是,分析你的項(xiàng)目結(jié)構(gòu),找到JavaSc...
摘要:除此之外,你還可以運(yùn)行打包命令此時(shí)之前說的打包生成的文件應(yīng)該就生成了,或者選擇用瀏覽器打開應(yīng)該也可以看見和剛剛一樣的結(jié)果。而如何創(chuàng)建一個(gè)對(duì)象是知道,因此開頭引入了,并使用它常見了一個(gè)對(duì)象,然后這個(gè)對(duì)象就管理了這一塊區(qū)域。 作者:心葉時(shí)間:2018-04-25 16:33 本篇最終項(xiàng)目文件Github地址:github.com/paper520/vue.quick/tree/V1 Vue...
摘要:可用編譯低版本代碼水有多深不得而知啟動(dòng)新技術(shù)提供測試框架進(jìn)行單元測試,代碼覆蓋率報(bào)告,可與和快速對(duì)接。頁面的其他資源文件,通過引入單元測試項(xiàng)目啟動(dòng)環(huán)境配置為了把保證項(xiàng)目正常運(yùn)行,請(qǐng)自行更新相關(guān)環(huán)境。 項(xiàng)目地址:https://github.com/sayll/ie-webpack-start ie-webpack-start showImg(https://segmentfault....
摘要:先看下官方文檔中對(duì)模塊的描述在模塊化編程中,開發(fā)者將程序分解成離散功能塊,并稱之為模塊。每個(gè)模塊具有比完整程序更小的接觸面,使得校驗(yàn)調(diào)試測試輕而易舉。 先看下webpack官方文檔中對(duì)模塊的描述: 在模塊化編程中,開發(fā)者將程序分解成離散功能塊(discrete chunks of functionality),并稱之為模塊。每個(gè)模塊具有比完整程序更小的接觸面,使得校驗(yàn)、調(diào)試、測試輕而易...
閱讀 1373·2021-11-16 11:45
閱讀 2315·2021-11-02 14:40
閱讀 3966·2021-09-24 10:25
閱讀 3079·2019-08-30 12:45
閱讀 1362·2019-08-29 18:39
閱讀 2532·2019-08-29 12:32
閱讀 1738·2019-08-26 10:45
閱讀 1980·2019-08-23 17:01