Vue项目总结之webpack常规打包优化方案


Posted in Javascript onJune 06, 2019

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

分析打包文件

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

打包后生成文件分析

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

安装

npm i webpack-bundle-analyzer -D

使用

修改 webpack.prod.conf.js 文件

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin

// 构建完成后,浏览器会自动打开localhost:8080
webpackConfig.plugins.push(
 new BundleAnalyzerPlugin({
  analyzerPort: 8080,
  generateStatsFile: false
 })
)

Vue项目总结之webpack常规打包优化方案

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

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

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()
 ]
...

效果如下:

 Vue项目总结之webpack常规打包优化方案

资源与依赖包的控制

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

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

  • 项目中没有使用的依赖可以删除,可以按需引用的依赖,按需引用
  • 项目里面使用 ElementUI 和 Echarts 都是全部引用挂在 Vue.prototype 上,现都改为按需引用。

减少文件搜索范围

设置 resolve.alias 字段,避免打包时如果使用相对路径访问或着 import 文件时会层层去查找解析文件

resolve: {
 alias: {
  '@': resolve('src')
 }
}

合理配置 extensions 扩展名

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

resolve: {
 extensions: ['.vue', '.js']
}

loader 预处理文件增加 include 匹配特定条件

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

happypack 多线程执行

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

安装

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 分钟,整体还有优化空间,可以使用其他 cdn , dll 等优化方式。

以上所述是小编给大家介绍的Vue项目总结之webpack常规打包优化方案,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
再论Javascript下字符串连接的性能
Mar 05 Javascript
基于jquery的监控数据是否发生改变
Apr 11 Javascript
简单实用的全选反选按钮例子
Oct 18 Javascript
PHP 数组current和next用法分享
Mar 05 Javascript
剖析Node.js异步编程中的回调与代码设计模式
Feb 16 Javascript
jQuery stop()用法实例详解
Jul 28 Javascript
JS+canvas动态绘制饼图的方法示例
Sep 12 Javascript
微信小程序block的使用教程
Apr 01 Javascript
vue-cli项目中使用Mockjs详解
May 14 Javascript
JavaScript链式调用实例浅析
Dec 19 Javascript
vue打包静态资源后显示空白及static文件路径报错的解决
Sep 02 Javascript
JavaScript中document.activeELement焦点元素介绍
Nov 27 Javascript
vue-cli脚手架打包静态资源请求出错的原因与解决
Jun 06 #Javascript
详解vue-cli@2.x项目迁移日志
Jun 06 #Javascript
详解新手使用vue-router传参时注意事项
Jun 06 #Javascript
vue-cli配置全局sass、less变量的方法
Jun 06 #Javascript
解决vue组件props传值对象获取不到的问题
Jun 06 #Javascript
webpack4之如何编写loader的方法步骤
Jun 06 #Javascript
vue 插件的方法代码详解
Jun 06 #Javascript
You might like
php 无限级 SelectTree 类
2009/05/19 PHP
用PHP的超级变量$_GET获取HTML表单(Form) 数据
2011/05/07 PHP
ThinkPHP3.1新特性之动态设置自动完成和自动验证示例
2014/06/19 PHP
php使用imagecopymerge()函数创建半透明水印
2018/01/25 PHP
PHP按一定比例压缩图片的方法
2018/10/12 PHP
laravel 事件/监听器实例代码
2019/04/12 PHP
Laravel框架实现调用百度翻译API功能示例
2019/05/30 PHP
解决Laravel5.2 Auth认证退出失效的问题
2019/10/14 PHP
php设计模式之迭代器模式实例分析【星际争霸游戏案例】
2020/04/07 PHP
为JavaScript提供睡眠功能(sleep) 自编译JS引擎
2010/08/16 Javascript
JavaScript利用构造函数和原型的方式模拟C#类的功能
2014/03/06 Javascript
jQuery+PHP星级评分实现方法
2015/10/02 Javascript
举例说明如何为JavaScript的方法参数设置默认值
2015/11/17 Javascript
jQuery实现的AJAX简单弹出层效果代码
2015/11/26 Javascript
再谈JavaScript异步编程
2016/01/27 Javascript
Vue.JS入门教程之自定义指令
2016/12/08 Javascript
解析JavaScript实现DDoS攻击原理与保护措施
2016/12/26 Javascript
JS中mouseup事件丢失的原因与解决办法
2017/06/14 Javascript
深入讲解xhr(XMLHttpRequest)/jsonp请求之abort
2017/07/26 Javascript
Vue服务器渲染Nuxt学习笔记
2018/01/31 Javascript
vue实现单一筛选、删除筛选条件
2020/10/26 Javascript
Pycharm学习教程(7)虚拟机VM的配置教程
2017/05/04 Python
解决python 自动安装缺少模块的问题
2018/10/22 Python
pycharm修改file type方式
2019/11/19 Python
解决PyCharm无法使用lxml库的问题(图解)
2020/12/22 Python
HTML5 Canvas中使用用路径描画圆弧
2015/01/01 HTML / CSS
校三好学生主要事迹
2014/01/11 职场文书
幼儿园中班教学反思
2014/02/10 职场文书
空乘英文求职信
2014/04/13 职场文书
学习演讲稿范文
2014/05/10 职场文书
技术负责人岗位职责
2015/02/10 职场文书
加薪通知
2015/04/25 职场文书
协议书格式模板
2016/03/24 职场文书
创业计划书之零食店(进口)
2019/09/24 职场文书
Mysql systemctl start mysqld报错的问题解决
2021/06/03 MySQL
Ajax 的初步实现(使用vscode+node.js+express框架)
2021/06/18 Javascript