设为首页 - 加入收藏 ASP站长网(Aspzz.Cn)- 科技、建站、经验、云计算、5G、大数据,站长网!
热搜: 重新 试卷 文件
当前位置: 首页 > 运营中心 > 建站资源 > 优化 > 正文

浅谈 Webpack 背后的运行机制(6)

发布时间:2019-08-15 12:49 所属栏目:21 来源:Alan
导读:关于第一点,我们回忆一下之前 __webpack_require__.e 的内容,此时 chunk 还处于「加载中」的状态,也就是说对应的 installedChunks[chunkId] 的值此时为 [resolve, reject, promise]。而这里,chunk 已经加载,但

关于第一点,我们回忆一下之前 __webpack_require__.e 的内容,此时 chunk 还处于「加载中」的状态,也就是说对应的 installedChunks[chunkId] 的值此时为 [resolve, reject, promise]。而这里,chunk 已经加载,但 promise 还未决议,于是 webpackJsonpCallback 内部定义了一个 resolves 变量用来收集 installedChunks 上的 resolve 并执行它。

接下来说到第二点,就要涉及几个层面的缓存了。

首先是 chunk 层面,这里有两个相关操作,操作一将 installedChunks[chunkId] 置为 0 可以让 __webpack_require__.e 在第二次加载同一 chunk 时返回一个立即决议的 promise(Promise.all([]));操作二将 chunk data 添加进 window["webpackJsonp"] 数组,可以在多入口模式时,方便地拿到已加载过的 chunk 缓存。通过以下代码实现:

  1. /*** 缓存执行部分 ***/ 
  2. var jsonpArray = window["webpackJsonp"] = window["webpackJsonp"] || []; 
  3. // ... 
  4. for (var i = 0; i < jsonpArray.length; i++) webpackJsonpCallback(jsonpArray[i]); 
  5. var parentJsonpFunction = oldJsonpFunction; 
  6. /*** 缓存执行部分 ***/ 
  7. /*** 缓存添加部分 ***/ 
  8. function webpackJsonpCallback(data) { 
  9. //... 
  10. // 此处的 parentJsonpFunction 是 window["webpackJsonp"] 数组的原生 push 
  11. if (parentJsonpFunction) parentJsonpFunction(data); 
  12. //... 
  13. /*** 缓存添加部分 ***/ 

而在 modules 层面, chunk 中的 moreModules 被合入入口文件的 modules 中,可供下一个微任务中的 __webpack_require__ 同步加载模块。

  1. ({ 
  2. "./src/index.js": 
  3. (function (module, exports, __webpack_require__) { 
  4. console.log( Hello webpack! ); 
  5. window.setTimeout(() => { 
  6. __webpack_require__.e(0).then(__webpack_require__.bind(null, "./src/utils/math.js")).then(mathUtil => { 
  7. console.log( 1 + 2: + mathUtil.plus(1, 2)); 
  8. }); 
  9. }, 2000); 
  10. }) 
  11. }); 

__webpack_require__.e(0) 返回的 promise 决议后, __webpack_require__.bind(null,"./src/utils/math.js") 可以加载到 chunk 携带的模块,并返回模块作为下一个微任务函数的入参,接下来就是 Webpack Loader 翻译过的其他业务代码了。

现在让我们把异步流程梳理一下:

浅谈 Webpack 背后的运行机制

(编辑:ASP站长网)

网友评论
推荐文章
    热点阅读