webpack(3) webpack打包结果分析

一  以devtool是source-map的情况下, webpack打包的结果, 即经过webpack打包后生成的文件:

1. webpack打包的最终结果, 是一个合并了所有模块的js文件.

2. 该文件为了防止变量污染全局, 整体是一个立即执行函数.

3.定义了一个__webpack_modules__对象;属性名是各个模块的路径,属性值是一个函数, 该函数的参数有三个: module, export , require, 函数体是模块本    身的内容

 

 

4. 定义一个reuire函数; 因为在index.js中导入其他模块,webpack内部把require和import都正常了require函数的执行

 

 

 

 通过__webpack_modules__[moduleId]函数的执行, 会引入依赖, 在index.js执行的作用域中去引入, 即在此通过执行__webpack_modules__[moduleId]函数, 按照导入顺序, 形成一个导入的作用域链, 知道所有引入都加载完, 然后开始导出,和执行多个内部函数是一样的.

二. devtool : 是对sourcemap技术的引用, 打包结果做不同的处理, 其中

         开发过程用"eval-source-map"

 

              或者"source-map";

 

 

 

后者会生成单独的map文件,

         这样在浏览器中检查会定位到源文件

 

因为在eval中有 //# sourceURL=xxx 这种注释;会通过注释去寻找

 

posted @ 2021-03-05 18:20  当当和瓶瓶  阅读(472)  评论(0编辑  收藏  举报