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

性能优化篇---Webpack构建速度优化(2)

发布时间:2019-03-15 16:30 所属栏目:21 来源:keywords
导读:使用DllPlugin优化 在使用webpack进行打包时候,对于依赖的第三方库,如react,react-dom等这些不会修改的依赖,可以让它和业务代码分开打包; 只要不升级依赖库版本,之后webpack就只需要打包项目业务代码,遇到需

使用DllPlugin优化

  •  在使用webpack进行打包时候,对于依赖的第三方库,如react,react-dom等这些不会修改的依赖,可以让它和业务代码分开打包;
  •  只要不升级依赖库版本,之后webpack就只需要打包项目业务代码,遇到需要导入的模块在某个动态链接库中时,就直接去其中获取;而不用再去编译第三方库,这样第三方库就只需要打包一次。
  •  接入需要完成的事:

        1. 将依赖的第三方模块抽离,打包到一个个单独的动态链接库中

        2. 当需要导入的模块存在动态链接库中时,让其直接从链接库中获取

        3. 项目依赖的所有动态链接库都需要被加载

  •  接入工具(webpack已内置)

        1. DllPlugin插件:用于打包出一个个单独的动态链接库文件;

        2. DllReferencePlugin:用于在主要的配置文件中引入DllPlugin插件打包好的动态链接库文件

  •  配置webpack_dll.config.js构建动态链接库 
  1. const path = require('path');  
  2. const DllPlugin = require('webpack/lib/DllPlugin');  
  3. module.exports = {  
  4.     mode: 'production',  
  5.     entry: {  
  6.         // 将React相关模块放入一个动态链接库  
  7.         react: ['react','react-dom','react-router-dom','react-loadable'],  
  8.         librarys: ['wangeditor'],  
  9.         utils: ['axios','js-cookie']  
  10.     },  
  11.     output: {  
  12.         filename: '[name]-dll.js',  
  13.         path: path.resolve(__dirname, 'dll'),  
  14.         // 存放动态链接库的全局变量名,加上_dll_防止全局变量冲突  
  15.         library: '_dll_[name]'  
  16.     },  
  17.     // 动态链接库的全局变量名称,需要可output.library中保持一致,也是输出的manifest.json文件中name的字段值  
  18.     // 如react.manifest.json字段中存在"name":"_dll_react"  
  19.     plugins: [  
  20.         new DllPlugin({  
  21.             name: '_dll_[name]',  
  22.             path: path.join(__dirname, 'dll', '[name].manifest.json')  
  23.         })  
  24.     ]  
  •  webpack.pro.config.js中使用 
  1. const DllReferencePlugin = require('webpack/lib/DllReferencePlugin');  
  2. ...  
  3. plugins: [  
  4.     // 告诉webpack使用了哪些动态链接库  
  5.         new DllReferencePlugin({  
  6.             manifest: require('./dll/react.manifest.json')  
  7.         }),  
  8.         new DllReferencePlugin({  
  9.             manifest: require('./dll/librarys.manifest.json')  
  10.         }),  
  11.         new DllReferencePlugin({  
  12.             manifest: require('./dll/utils.manifest.json')  
  13.         }),  
  •  注意:在webpack_dll.config.js文件中,DllPlugin中的name参数必须和output.library中的一致;因为DllPlugin的name参数影响输出的manifest.json的name;而webpack.pro.config.js中的DllReferencePlugin会读取manifest.json的name,将值作为从全局变量中获取动态链接库内容时的全局变量名
  •  执行构建

        1. webpack --progress --colors --config ./webpack.dll.config.js

        2. webpack --progress --colors --config ./webpack.prod.js

  •  html中引入dll.js文件
  •  构建时间对比:["11593ms","10654ms","8334ms"]

(编辑:ASP站长网)

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