基于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 相关文章推荐
Easy.Ajax 部分源代码 支持文件上传功能, 兼容所有主流浏览器
Feb 24 Javascript
css与javascript跨浏览器兼容性总结
Sep 15 Javascript
使用JS获取当前地理位置方法汇总
Dec 18 Javascript
Javascript控制input输入时间格式的方法
Jan 28 Javascript
JavaScript+CSS实现仿天猫侧边网页菜单效果
Aug 25 Javascript
详解JavaScript时间处理之几个月前或几个月后的指定日期
Dec 21 Javascript
使用vue-router完成简单导航功能【推荐】
Jun 28 Javascript
Bootstrap Table实现定时刷新数据的方法
Aug 13 Javascript
原生js检测页面加载完毕的实例
Sep 11 Javascript
深入浅析javascript函数中with
Oct 28 Javascript
Node.js 如何利用异步提升任务处理速度
Jan 07 Javascript
es6中Promise 对象基本功能与用法实例分析
Feb 23 Javascript
解决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
晶体管来复再生式二管收音机
2021/03/02 无线电
关于文本留言本的分页代码
2006/10/09 PHP
PHP获取用户的浏览器与操作系统信息的代码
2012/09/04 PHP
php缩放图片(根据宽高的等比例缩放)实例介绍
2013/06/09 PHP
简单说说PHP优化那些事(经验分享)
2014/11/27 PHP
PHP7新增运算符用法实例分析
2016/09/26 PHP
php 生成签名及验证签名详解
2016/10/26 PHP
PHP实现使用DOM将XML数据存入数组的方法示例
2017/09/27 PHP
JavaScript 实现模态对话框 源代码大全
2009/05/02 Javascript
javascript学习笔记(十四) window对象使用介绍
2012/06/20 Javascript
JS打印gridview实现原理及代码
2013/02/05 Javascript
jquery对象和javascript对象即DOM对象相互转换
2014/08/07 Javascript
js实现遍历含有input的table实例
2015/12/07 Javascript
Bootstrap 粘页脚效果
2016/03/28 Javascript
使用jQuery操作DOM的方法小结
2017/02/27 Javascript
JavaScript数据结构与算法之二叉树遍历算法详解【先序、中序、后序】
2019/02/21 Javascript
JS实现可切换图片的幻灯切换效果示例
2019/05/24 Javascript
react koa rematch 如何打造一套服务端渲染架子
2019/06/26 Javascript
JS为什么说async/await是generator的语法糖详解
2019/07/11 Javascript
vue 实现input表单元素的disabled示例
2019/10/28 Javascript
jQuery-App输入框实现实时搜索
2020/11/19 jQuery
python中的split()函数和os.path.split()函数使用详解
2019/12/21 Python
tensorflow 限制显存大小的实现
2020/02/03 Python
python爬虫库scrapy简单使用实例详解
2020/02/10 Python
Python基础之列表常见操作经典实例详解
2020/02/26 Python
html5 Canvas画图教程(9)—canvas中画出矩形和圆形
2013/01/09 HTML / CSS
英国天然保健品网站:Simply Supplements
2017/03/22 全球购物
Vichy薇姿加拿大官网:法国药妆,全球专业敏感肌护肤领先品牌
2018/07/11 全球购物
奢华时尚的创新平台:Baltini
2020/10/03 全球购物
什么是数据库锁?Oracle中都有哪些类型的锁?
2015/08/21 面试题
介绍一下JNDI的基本概念
2013/07/26 面试题
在求职信中如何凸显个人优势
2013/10/30 职场文书
图书室管理制度
2014/01/19 职场文书
毕业评语大全
2014/05/04 职场文书
销售求职信范文
2014/05/26 职场文书
2016猴年开门红标语口号
2015/12/26 职场文书