博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
【Vue项目总结】webpack常规打包优化方案
阅读量:5814 次
发布时间:2019-06-18

本文共 2327 字,大约阅读时间需要 7 分钟。

由于新建项目发版打包时间大概需要30分钟,发版时严重拖慢下班时间,所以特意查看了相关文档来优化打包速度,争取早点下班,^_^。

分析打包文件

要优化,先分析。我们先要知道到底是哪里拖慢我们的打包速度呢?

打包后生成文件分析

可以利用webpack-bundle-analyzer插件来分析我们打包后生成的文件

  • 安装
npm i webpack-bundle-analyzer -D复制代码
  • 使用

修改webpack.prod.conf.js文件

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin// 构建完成后,浏览器会自动打开localhost:8080webpackConfig.plugins.push(  new BundleAnalyzerPlugin({    analyzerPort: 8080,    generateStatsFile: false  }))复制代码

通过图片可以看到打包后文件的具体信息

打包进度条显示,可以查看到打包进度百分比

simple-progress-webpack-plugin可以显示打包百分比

  • 安装
npm i simple-progress-webpack-plugin -D复制代码
  • 使用

修改webpack.prod.conf.js文件

const SimpleProgressWebpackPlugin = require( 'simple-progress-webpack-plugin' )...  plugins: [    new SimpleProgressWebpackPlugin()  ]...复制代码

效果如下:

资源与依赖包的控制

通过上面进度可以看到,打包过程中,卡顿在压缩的地方过长,当项目越来越臃肿的时候,我们要需要对项目静态资源以及依赖包进行整理,

  • 图片过大的可以压缩,这里推荐一个还不错的压缩

  • 项目中没有使用的依赖可以删除,可以按需引用的依赖,按需引用

项目里面使用ElementUIEcharts都是全部引用挂在Vue.prototype上,现都改为按需引用。

减少文件搜索范围

  • 设置resolve.alias字段,避免打包时如果使用相对路径访问或着import文件时会层层去查找解析文件
resolve: {  alias: {    '@': resolve('src')  }}复制代码
  • 合理配置extensions扩展名

resolve.extensions能够自动解析确定的扩展,但是如果extensions扩展名过多,会导致解析过程过多,所以我们要合理配置扩展名,不要过多配置扩展名,项目引用多的文件,扩展名放在前面,我司项目中多的是vuejs文件,可以只引用这两种。

resolve: {  extensions: ['.vue', '.js']}复制代码
  • loader预处理文件增加include匹配特定条件

预处理各种文件时指定匹配目录后,webpack解析文件时就不会循环查找其他目录,加快解析速度。

happypack多线程执行

webpack执行预处理文件时单线程的,我们可以使用来多线程处理文件。

  • 安装
npm i happypack  -D复制代码
  • 使用

修改webpack.base.js文件

const happyThreadPool = HappyPack.ThreadPool({ size: os.cpus().length });module: {  rules: [    {      test: /\.js$/,      loader: 'happypack/loader?id=babel', // 原始loader替换成`happypack/loader`      include: [resolve('src')]    }  ]},plugins: [  new HappyPack({    // id标识 需要处理的loader    id: 'babel',    // loader配置和原始配置一样    loaders: [      {        loader: 'babel-loader',        options: {          presets: ['es2015'],          cacheDirectory: true        }      }    ],    threadPool: happyThreadPool  })]复制代码

babel-plugin-dynamic-import-node异步加载

babel-plugin-dynamic-import-node插件是使import() 替换成 require 编译

  • 安装
npm i babel-plugin-dynamic-import-node -D复制代码
  • 使用

修改.babelrc 文件

"env": {  "development": {    "plugins": ["dynamic-import-node"]  },  "production": {    "plugins": ["dynamic-import-node"]  }}复制代码

注意:使用插件build后没有chunk files文件。

总结

项目经过以上优化,打包从30分钟,到2分钟,整体还有优化空间,可以使用其他cdndll等优化方式。

文章首发于;其他系列文章:

转载地址:http://fvxbx.baihongyu.com/

你可能感兴趣的文章
linux 常见音乐、视频播放器简介
查看>>
WebDriver 将浏览器窗口最大化
查看>>
判断js中的数据类型的几种方法
查看>>
java-JDBC
查看>>
Python Day46
查看>>
nginx应用
查看>>
哈哈,CSDN又支持Windows Live Writer了
查看>>
HTML&CSS总结
查看>>
python中利用logging包进行日志记录时的logging.level设置选择
查看>>
面试题36:数组中的逆序对
查看>>
如何调试shell脚本
查看>>
keras安装简介(windows)
查看>>
h5 离线缓存小demo
查看>>
定制 黑色描边、白色背景、带圆角 的背景
查看>>
Gradle安装
查看>>
TrueSkill 原理及实现
查看>>
pytorch之nn.Conv1d详解
查看>>
xcode 常用的一些快捷键
查看>>
UnQLite简介
查看>>
洛谷P2664 树上游戏(点分治)
查看>>