欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

淺談Webpack 是如何加載模塊的

 更新時(shí)間:2018年05月24日 09:46:56   作者:MockingBird  
這篇文章主要介紹了Webpack 是如何加載模塊的,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧

Webpack 在前端開發(fā)中作為模塊打包工具非常受開發(fā)者的青睞,豐富的 loader 使它可以實(shí)現(xiàn)各種各樣的功能。本文將通過 webpack 來打包一個(gè) js 文件,看看 webpack 是如何加載各個(gè)模塊的。

兩個(gè)簡單的源文件

為了方便分析 webpack 加載模塊的原理,我們準(zhǔn)備了兩個(gè)文件:

hello.js

const hello = {
 say: arg => {
  console.info('hello ' + arg || 'world');
 }
};

export default hello;

index.js

import Hello from './hello';

Hello.say('man');

index.js 作為入口文件,引用了 hello.js 模塊。

Webpack 打包

在命令行執(zhí)行 webpack index.js bundle.js 對入口文件進(jìn)行打包,生成 bundle.js ,大體結(jié)構(gòu)為(為了方便閱讀,我刪除了部分多余的代碼):

可以看到,最終生成的文件以 (function (modules) {})([模塊1, 模塊2]) 的方式啟動,我們定義的模塊被包裝成一個(gè)個(gè)匿名函數(shù),然后以數(shù)組的形式傳遞個(gè)一個(gè)匿名函數(shù) function (modules) {},在這個(gè)匿名函數(shù)中定義了一個(gè) __webpack_require__() 函數(shù),用來加載模塊,最后,通過 return __webpack_require__(__webpack_require__.s = 0); 來加載第一個(gè)模塊 index.js

__webpack_require__() 函數(shù)

該函數(shù)接收一個(gè) moduleId 作為參數(shù),這個(gè)參數(shù)就是各個(gè)模塊在數(shù)組中的索引,

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)
  /******/
  var module = installedModules[moduleId] = {
   /******/
   i: moduleId,
   /******/
   l: false,
   /******/
   exports: {}
   /******/
  };
  /******/
  /******/ // Execute the module function
  /******/
  modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);
  /******/
  /******/ // Flag the module as loaded
  /******/
  module.l = true;
  /******/
  /******/ // Return the exports of the module
  /******/
  return module.exports;
  /******/
 }

其中 installedModules 是用來緩存執(zhí)行過的模塊。通過 modules[moduleId].call() 來執(zhí)行模塊,最后返回模塊的 exports。

模塊接受的參數(shù)

以 hello.js 模塊為例

 (function (module, __webpack_exports__, __webpack_require__) {

  "use strict";
  const hello = {
   say: arg => {
    console.info('hello ' + arg || 'world');
   }
  };

  /* harmony default export */
  __webpack_exports__["a"] = (hello);

  /***/
 })

webpack 會向模塊傳遞 module, __webpack_exports__, __webpack_require__ 三個(gè)參數(shù),前兩個(gè)是用來導(dǎo)出模塊內(nèi)的變量,第三個(gè)參數(shù)為前面介紹的 __webpack_require__() 的引用,用來導(dǎo)入其它模塊。

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • JavaScript中使用Spread運(yùn)算符的八種方法總結(jié)

    JavaScript中使用Spread運(yùn)算符的八種方法總結(jié)

    這篇文章主要給大家介紹了JavaScript中使用Spread運(yùn)算符的八種方法,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用JavaScript具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-06-06
  • javascript 構(gòu)建模塊化開發(fā)過程解析

    javascript 構(gòu)建模塊化開發(fā)過程解析

    這篇文章主要介紹了javascript 構(gòu)建模塊化開發(fā)過程解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-09-09
  • JS前端分片上傳大文件步驟(支持1G以上的超大文件)

    JS前端分片上傳大文件步驟(支持1G以上的超大文件)

    當(dāng)前端在開發(fā)過程中遇到上傳文件需求,如果是小文件之類的可以正常按上傳流程處理,但是當(dāng)遇到上傳大文件需求時(shí)就需要分片上傳,這篇文章主要給大家介紹了關(guān)于JS前端分片上傳大文件(支持1G以上的超大文件)的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • 小試小程序云開發(fā)(小結(jié))

    小試小程序云開發(fā)(小結(jié))

    這篇文章主要介紹了小試小程序云開發(fā)(小結(jié)),小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-06-06
  • JS簡單實(shí)現(xiàn)自定義右鍵菜單實(shí)例

    JS簡單實(shí)現(xiàn)自定義右鍵菜單實(shí)例

    本篇文章主要介紹了JS簡單實(shí)現(xiàn)自定義右鍵菜單實(shí)例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-05-05
  • javascript動態(tài)分頁的實(shí)現(xiàn)方法實(shí)例

    javascript動態(tài)分頁的實(shí)現(xiàn)方法實(shí)例

    最近的項(xiàng)目需要添加一個(gè)分頁導(dǎo)航的功能,沒有用網(wǎng)上封裝好的文件,通過JS自己簡單實(shí)現(xiàn)了效果,這篇文章主要給大家介紹了關(guān)于javascript動態(tài)分頁的實(shí)現(xiàn)方法,需要的朋友可以參考下
    2022-06-06
  • 原生js代碼能實(shí)現(xiàn)call和bind嗎

    原生js代碼能實(shí)現(xiàn)call和bind嗎

    這篇文章主要介紹了原生js代碼能實(shí)現(xiàn)call和bind嗎,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • Extjs4實(shí)現(xiàn)兩個(gè)GridPanel之間數(shù)據(jù)拖拽功能具體方法

    Extjs4實(shí)現(xiàn)兩個(gè)GridPanel之間數(shù)據(jù)拖拽功能具體方法

    這篇文章主要介紹了Extjs4實(shí)現(xiàn)兩個(gè)GridPanel之間數(shù)據(jù)拖拽功能具體方法,有需要的朋友可以參考一下
    2013-11-11
  • 如何學(xué)JavaScript?前輩的經(jīng)驗(yàn)之談

    如何學(xué)JavaScript?前輩的經(jīng)驗(yàn)之談

    這篇文章主要介紹了如何學(xué)JavaScript?前輩的經(jīng)驗(yàn)之談,也就是怎么學(xué)前端的問題,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-12-12
  • 利用JS十分鐘判斷數(shù)組中存在元素的多種方式

    利用JS十分鐘判斷數(shù)組中存在元素的多種方式

    這篇文章主要給大家介紹了關(guān)于利用JS十分鐘判斷數(shù)組中存在元素的多種方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-03-03

最新評論