【疑难杂症】vue-cli热更新失效

前情提要

公司又双叒要搭建新的前端项目,以前用vue-cli3.0,所以这次就是用vue-cli4来搭建一下玩玩。

结果玩不好,vue-cli搭建的vue项目,部分热更新失败。主要体现在:1..vue文件的修改,可以实现热更新;2.在main.js等引入的文件,无法实现热更新。

过程

私以为是vue-cli版本不同导致的,所以在找度娘的过程中,也指定了是vue-cli4

结果试过很多方法:

1.配置vue.config.js,几个关键的属性也都开了

devServer: {
    hot: true,
    hotOnly: true,
    inline: true
}

chainWebpack: (config) => {
    config.resolve.symlinks(true);
}

2.使用webpack-dev-server

npm/cnpm i -D webpack-dev-server

// 执行命令
"serve": "cross-env NODE_ENV=dev vue-cli-service serve && webpack-dev-server --hot-only"

但依然是全局文件热更新失效

经过几番周折,决定静下心去看webpack4.0的官方文档

原来是需要HotModuleReplacementPlugin配合使用,但文档也说了,如果是通过--hot启动,会自动添加

唉,那么我就用 vue-cli HotModuleReplacementPlugin 试着去百度(重点来了)

然后看到了这位博主的vue-cli hot-module-replacement不生效,不自动更新文章,真一语点醒傻子般的我梦中人

解决

新项目和以前的项目的不同点在于,还没有新建环境配置文件(后续也许也不会直接在根目录下创建环境配置文件,因为环境太多了)

也就是说,没有.env.development文件的,NODE_ENV变量是使用cross-env去设置的

原来的命令如下

"serve": "cross-env NODE_ENV=dev vue-cli-service serve"

指定了NODE_ENV的值为dev,但vue-cli-service命令没有指定mode为dev(mode值默认为development),所以部分热更新失败

只要把命令修改为:

"serve": "cross-env NODE_ENV=dev vue-cli-service serve --mode dev"

热更新就奏效了。

还有最简单的,就是把NODE_ENV设置为development。

造成部分热更新失效的原因,我猜测是在vue-cli脚手架对热更新的配置中,process.env.NODE_ENVmode的值是有关系的。

vue-cli的mode在serve命令中,默认是"development",而如果不显式配置NODE_ENV的值,估计是null(不敢断定,还没去验证)

所以总结:

NODE_ENV和vue-cli的mode值要一一匹配!

后续:vue-cli-service的源码看了部分,感觉不是一时半刻能理解并且证实上面的猜测,所以先去搬砖,希望后续有时间能验证吧

 

  • 8
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
在使用Docker时,可能会遇到一些疑难。其中,一些常见的问题及解决办法如下: 1. 运行docker version时报错"Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?"这个错误通常是由于Docker守护进程未启动引起的。可以通过运行以下命令来启动守护进程:`sudo systemctl start docker`(适用于基于systemd的Linux发行版)。如果您不是使用systemd,请根据您的操作系统和版本来启动Docker守护进程。 2. 使用yum安装Docker时报错"Cannot retrieve metalink for repository: epel. Please verify its path and try again."这个错误通常是由于epel源(Extra Packages for Enterprise Linux)未正确安装或配置引起的。您可以尝试以下解决办法: - 首先,确保您的系统与互联网连接正常。 - 检查您的操作系统和版本,并根据官方文档正确安装epel源。 - 如果您已经安装了epel源,但仍然遇到这个错误,请尝试更新epel源并再次运行安装命令。 这些是一些常见的Docker疑难及其解决办法。当然,Docker的使用过程中可能还会遇到其他问题,您可以参考官方文档、社区论坛或搜索引擎来寻找更多解决办法。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [docker 疑难](https://blog.csdn.net/weixin_33805992/article/details/92266045)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [docker常见疑难](https://blog.csdn.net/weixin_45776707/article/details/103142818)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值