详解webpack 热更新优化


Posted in Javascript onSeptember 13, 2018

前言

随着项目的界面越来越多,webpack的热更新越来越慢,有时会达到5,7s之久,这对于开发效率影响是非常巨大的。

分析过程

于是今天就针对这个分析了一下热更新慢的原因,步骤如下

首先先在package中的启动命令加上

--progress --watch --colors --profile

先解释一下这几个参数的含义

  • --progress 构建进度
  • --watch 实时监测
  • --profile 编译过程中的步骤耗时时间

加上了这几个参数,重启项目,就可以开始观察耗时时间了,修改了某个文件之后,查看控制台,如下

详解webpack 热更新优化

图中红色部分就是耗时最长的地方了,好了,发现了耗时时间长的地方了,经过百度搜索,发现也有个问题和我这个非常类似,他的原因是因为使用了uglifyJsPlugin插件,这么一想,我的项目中的webpack配置中也用到了这个插件,于是把这个插件移到生产环境中使用,修改之后重启项目,修改某个文件之后,查看控制台,如下

详解webpack 热更新优化

效果非常惊人,总的耗时已经在1,2s之内了,效率提高了不少!!如果也有这种烦恼的小伙伴也可以试一下哦

另一种解决方案

这种方案的思路为,开发环境中,每人负责的都是一部分模块或者组件,所以热更新可以只编译自己当前需要的页面,而没必要把所有的页面全部编译。创建一个 selfConfig.js 设置需要保存的页面,然后在 webpack 配置中,配置,只属于需要的页面去编译热更新。加快开发环境中的编译速度。

// selfConfig.js
module.exports = [
'imScence',
'mLogin'
];
// webpack.base.conf.js 
// 部分关键代码
const selfConfig = require("./selfConfig");

for (let moduleName of modules) {
if (selfConfig.length === 0) {
devEntries[moduleName] = path.join(resolve('src'), 'modules', moduleName, 'main.js');
} else {
if (selfConfig.includes(moduleName)) {
devEntries[moduleName] = path.join(resolve('src'), 'modules', moduleName, 'main.js');
}
}
buildEntries[moduleName] = path.join(resolve('src'), 'modules', moduleName, 'main.js');
}

以上事例设置完成后,只会热更新两个页面,但是这种方案的弊端是,其他页面本地环境将是白屏打不开(因为压根没编译),所以这种方案还是根据适合自己的场景使用。

注意: 每次修改 selfConfig.js 需要重起 webpack 服务。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
在javascript将NodeList作为Array数组处理的方法
Jul 09 Javascript
jquery 圆形旋转图片滚动切换效果
Jan 19 Javascript
js中精确计算加法和减法示例
Mar 28 Javascript
教你如何使用node.js制作代理服务器
Nov 26 Javascript
C#中使用迭代器处理等待任务
Jul 13 Javascript
jQuery插件实现多级联动菜单效果
Dec 01 Javascript
jQuery提示插件qTip2用法分析(支持ajax及多种样式)
Jun 08 Javascript
jQuery获取this当前对象子元素对象的方法
Nov 29 Javascript
原生JS+Canvas实现五子棋游戏实例
Jun 19 Javascript
jQuery实现使用sort方法对json数据排序的方法
Apr 17 jQuery
Vue发布订阅模式实现过程图解
Apr 30 Javascript
react 路由Link配置详解
Nov 11 Javascript
Vue中使用 setTimeout() setInterval()函数的问题
Sep 13 #Javascript
Angularjs之ngModel中的值验证绑定方法
Sep 13 #Javascript
在小程序/mpvue中使用flyio发起网络请求的方法
Sep 13 #Javascript
解决angular2在双向数据绑定时[(ngModel)]无法使用的问题
Sep 13 #Javascript
mpvue中使用flyjs全局拦截的实现代码
Sep 13 #Javascript
AngularJS修改model值时,显示内容不变的实例
Sep 13 #Javascript
在vue中使用vue-echarts-v3的实例代码
Sep 13 #Javascript
You might like
Linux fgetcsv取得的数组元素为空字符串的解决方法
2011/11/25 PHP
PHP 面向对象程序设计(oop)学习笔记 (五) - PHP 命名空间
2014/06/12 PHP
PHP计算日期相差天数实例分析
2016/02/23 PHP
PHP商品秒杀问题解决方案实例详解【mysql与redis】
2019/07/22 PHP
JavaScript动态插入script的基本思路及实现函数
2013/11/11 Javascript
javascript初学者常用技巧
2014/09/02 Javascript
jQuery使用removeClass方法删除元素指定Class的方法
2015/03/26 Javascript
js+HTML5实现视频截图的方法
2015/06/16 Javascript
js闭包引起的事件注册问题介绍
2016/03/29 Javascript
实例解析Array和String方法
2016/12/14 Javascript
jQuery与js实现颜色渐变的方法
2016/12/30 Javascript
JS实现最简单的冒泡排序算法
2017/02/15 Javascript
vuejs绑定class和style样式
2017/04/11 Javascript
Vue 仿QQ左滑删除组件功能
2018/03/12 Javascript
微信小程序之判断页面滚动方向的示例代码
2018/08/30 Javascript
基于Vue2实现简易的省市区县三级联动组件效果
2018/11/05 Javascript
vue 中 beforeRouteEnter 死循环的问题
2019/04/23 Javascript
Vue v-text指令简单使用方法示例
2019/09/19 Javascript
python静态方法实例
2015/01/14 Python
python实现数值积分的Simpson方法实例分析
2015/06/05 Python
详解Python的Django框架中的中间件
2015/07/24 Python
Python文本处理之按行处理大文件的方法
2018/04/09 Python
python学习开发mock接口
2019/04/28 Python
PYQT5设置textEdit自动滚屏的方法
2019/06/14 Python
Python实现生成密码字典的方法示例
2019/09/02 Python
python config文件的读写操作示例
2019/09/27 Python
Python3.8对可迭代解包的改进及用法详解
2019/10/15 Python
python matplotlib拟合直线的实现
2019/11/19 Python
Python3 socket即时通讯脚本实现代码实例(threading多线程)
2020/06/01 Python
最简单的matplotlib安装教程(小白)
2020/07/28 Python
python调用jenkinsAPI构建jenkins,并传递参数的示例
2020/12/09 Python
欧洲最大的滑雪假期供应商之一:Sunweb Holidays
2018/01/06 全球购物
货车司机岗位职责
2014/03/18 职场文书
2014年十一国庆节爱国演讲稿
2014/09/23 职场文书
安全先进个人材料
2014/12/29 职场文书
详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)
2021/07/01 HTML / CSS