基于webpack-hot-middleware热加载相关错误的解决方法


Posted in Javascript onFebruary 22, 2018

错误1:找不到__webpack_hmr

GET http://127.0.0.1/__webpack_hmr 404 (Not Found)

在webpack的entry配置添加引用路径'webpack-hot-middleware/client?path=/__webpack_hmr&timeout=10000&reload=true',相关的参数最好不要省略,否则会出现无法自动刷新的问题。

处理脚本如下:

// 准备webpack配置信息
let hotMiddlewareScript = 'webpack-hot-middleware/client?path=/__webpack_hmr&timeout=10000&reload=true',
 wpConfig = require('./webpack.config'),
 // 准备修改配置信息
 entries = Object.keys(wpConfig.entry)

// 添加热加载信息
entries.forEach((key) => {
 wpConfig.entry[key].push(hotMiddlewareScript);
})

// 添加插件信息
if(wpConfig.plugins === undefined) {
 wpConfig.plugins = []
}

// 添加热加载插件
wpConfig.plugins.push(
 new webpack.optimize.OccurrenceOrderPlugin(),
 new webpack.HotModuleReplacementPlugin(),
 new webpack.NoEmitOnErrorsPlugin())

错误2:找不到hot-update.json

main.bundle.js:30 GET http://127.0.0.1/static/44588e3474a86cea5670.hot-update.json 404 (Not Found)

webpack配置中的publicPath必须是绝对地址,详细配置如下所示:

module.exports = {
 // 其他配置信息略
 // ……
 output : {
 path: configs.dist,
 // 必须是绝对地址
 publicPath: 'http://127.0.0.1/static/',
 filename : '[name].bundle.js',
 libraryTarget : 'var' 
 }
}

错误3:No ‘Access-Control-Allow-Origin' header

XMLHttpRequest cannot load http://127.0.0.1/static/df222441abc9ddb6a616.hot-update.json. No 'Access-Control-Allow-Origin' header is present on the requested resource. Origin 'http://localhost' is therefore not allowed access.

不可思议,在本地访问竟然会出现AJAX跨域问题,仔细检查后发现,浏览器把localhost与127.0.0.1当成了两个不同的域,解决的方法很多,只说最简单的一种,访问应用时,尽量采用与webpack配置中的publicPath完全一致的路径,如在本文中,最好的访问方法是输入http://127.0.0.1/访问本地应用。

错误4:OccurenceOrderPlugin构造器错误

new webpack.optimize.OccurenceOrderPlugin(),
TypeError: webpack.optimize.OccurenceOrderPlugin is not a constructor
 at Object.<anonymous> (E:\Workspace\vue-hot\dev-server.js:23:6)
 at Module._compile (module.js:570:32)
 at Object.Module._extensions..js (module.js:579:10)
 at Module.load (module.js:487:32)
 at tryModuleLoad (module.js:446:12)
 at Function.Module._load (module.js:438:3)
 at Module.runMain (module.js:604:10)
 at run (bootstrap_node.js:394:7)
 at startup (bootstrap_node.js:149:9)
 at bootstrap_node.js:509:3

此问题一般出现在webpack 2中,解决办法很简单,将OccurenceOrderPlugin改为OccurrenceOrderPlugin即可。

总结

webpack编译程序有两种热加载方式,webpack-dev-server与webpack-hot-middleware方式,从webpack 2的性能来看,webpack-dev-server完全能够满足开发的需要,但最大的问题在于,webpack-dev-server不能向外发布服务,只能在本地访问。

以上这篇基于webpack-hot-middleware热加载相关错误的解决方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript高级程序设计阅读笔记(六) ECMAScript中的运算符(二)
Feb 27 Javascript
javascript 拷贝节点cloneNode()使用介绍
Apr 03 Javascript
按钮接受回车事件的三种实现方法
Jun 06 Javascript
基于jQuery实现仿搜狐辩论投票动画代码(附源码下载)
Feb 18 Javascript
angularjs中ng-attr的用法详解
Dec 31 Javascript
JS实现二维数组横纵列转置的方法
Apr 17 Javascript
深入浅析Vue 中 ref 的使用
Apr 29 Javascript
深入浅出了解Node.js Streams
May 27 Javascript
详解vue+axios给开发环境和生产环境配置不同的接口地址
Aug 16 Javascript
基于js实现抽红包并分配代码实例
Sep 19 Javascript
vue使用@scroll监听滚动事件时,@scroll无效问题的解决方法详解
Oct 15 Javascript
Vue实现todo应用的示例
Feb 20 Vue.js
解决Webpack 热部署检测不到文件变化的问题
Feb 22 #Javascript
webpack-dev-server自动更新页面方法
Feb 22 #Javascript
javascript高仿热血传奇游戏实现代码
Feb 22 #Javascript
实现jquery放大镜的两种方法
Feb 22 #jQuery
JavaScript正则表达式函数总结(常用)
Feb 22 #Javascript
Node Puppeteer图像识别实现百度指数爬虫的示例
Feb 22 #Javascript
原生js调用json方法总结
Feb 22 #Javascript
You might like
功能齐全的PHP发送邮件类代码附详细说明
2008/07/10 PHP
PHP将进程作为守护进程的方法
2015/03/19 PHP
jquery关于图形报表的运用实现代码
2011/01/06 Javascript
js 编程笔记 无名函数
2011/06/28 Javascript
关于js遍历表格的实例
2013/07/10 Javascript
js replace 与replaceall实例用法详解
2013/08/03 Javascript
js实现仿Windows风格选项卡和按钮效果实例
2015/05/13 Javascript
javascript基于DOM实现省市级联下拉框的方法
2015/05/14 Javascript
深入解析JavaScript中函数的Currying柯里化
2016/03/19 Javascript
JavaScript中的ParseInt(&quot;08&quot;)和“09”返回0的原因分析及解决办法
2016/05/19 Javascript
浅谈JavaScript的函数及作用域
2016/12/30 Javascript
bootstrap table插件的分页与checkbox使用详解
2017/07/23 Javascript
axios进阶实践之利用最优雅的方式写ajax请求
2017/12/20 Javascript
vue.js系列中的vue-fontawesome使用
2018/02/10 Javascript
浅谈redux以及react-redux简单实现
2018/08/28 Javascript
Python中apply函数的用法实例教程
2014/07/31 Python
Python创建xml的方法
2015/03/10 Python
python实现基于两张图片生成圆角图标效果的方法
2015/03/26 Python
python异步实现定时任务和周期任务的方法
2019/06/29 Python
python中threading开启关闭线程操作
2020/05/02 Python
详解vscode实现远程linux服务器上Python开发
2020/11/10 Python
钉钉企业内部H5微应用开发详解
2020/05/12 HTML / CSS
使用HTML5加载音频和视频的实现代码
2020/11/30 HTML / CSS
阿迪达斯英国官方网站:adidas英国
2019/08/13 全球购物
DC Shoes澳大利亚官方网上商店:购买DC鞋子
2019/10/25 全球购物
以下为Windows NT 下的32 位C++程序,请计算sizeof 的值
2016/12/07 面试题
EJB的激活机制
2013/10/25 面试题
缴纳养老保险的证明
2014/01/10 职场文书
爱情保证书范文
2014/02/01 职场文书
小学生感恩父母演讲稿
2014/08/28 职场文书
2014业务员年终工作总结
2014/12/09 职场文书
六一晚会主持词开场白
2015/05/28 职场文书
党员证明模板
2015/06/19 职场文书
使用Selenium实现微博爬虫(预登录、展开全文、翻页)
2021/04/13 Python
Python3 多线程(连接池)操作MySQL插入数据
2021/06/09 Python
MySQL数据库查询进阶之多表查询详解
2022/04/08 MySQL