问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

__webpack-hmr 404怎么解决

发布网友 发布时间:2022-04-24 09:43

我来回答

2个回答

懂视网 时间:2022-05-15 02:09

这次给大家带来webpack 实现HMR,webpack 实现HMR的注意事项有哪些,下面就是实战案例,一起来看一下。

全称是Hot Module ReplaceMent(HMR),理解成热模块替换或者模块热替换都可以吧,和.net中的热插拔一个意思,就是在运行中对程序的模块进行更新。这个功能主要是用于开发过程中,对生产环境没有任何帮助(这一点区别.net热插拔)。效果上就是界面的无刷新更新。

HMR基于WDS,style-loader可以通过它来实现无刷新更新样式。但是对于JavaScript模块就需要做一点额外的处理,怎么处理继续往下看。因为HMR是用于开发环境的,所以我们修改下配置,做两份准备。一个用于生产,一个用于开发。

const path = require('path');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const webpack = require('webpack');
const PATHS = {
 app: path.join(__dirname, 'app'),
 build: path.join(__dirname, 'build'),
};
const commonConfig={
 entry: {
 app: PATHS.app,
 },
 output: {
 path: PATHS.build,
 filename: '[name].js',
 },
 plugins: [
 new HtmlWebpackPlugin({
 title: 'Webpack demo',
 }),
 ],
}
 
function developmentConfig(){
 const config ={
 devServer:{
 //使能历史记录api
 historyApiFallback:true,
 hotOnly:true,//关闭热替换 注释掉这行就行
 stats:'errors-only',
 host:process.env.Host,
 port:process.env.PORT,
 overlay:{
 errors:true,
 warnings:true,
 }
 },
 plugins: [
 new webpack.HotModuleReplacementPlugin(),
 ],
 };
 return Object.assign(
 {},
 commonConfig,
 config,
 {
 plugins: commonConfig.plugins.concat(config.plugins),
 }
 );
}
module.exports = function(env){
 console.log("env",env);
 if(env=='development'){
 return developmentConfig();
 }
 return commonConfig;
};

这个webpack.config.js建立了两个配置,一个是commonConfig,一个是developmentConfig 两者通过env参数来区分,但这个env参数是怎么来的呢?我们看看之前的package.json中的一段:

也就是说,如果按照上面的这个配置,我们通过npm start 启动的话,进入的就是开发环境配置,如果是直接build,那么就是生产环境的方式。build方式是第一节里面讲的 直接通过npm启动webpack,这就不带WDS了。另外有了一个Object.assign语法,将配置合并。这个时候通过npm start启动,控制台打印出了两条日志。

看起来HRM已经启动了。但是此时更新一下component.js

日志显示没有东西被热更新。而且这个39,36代表的是模块Id,看起来很不直观,这里可以通过一个插件使其更符合人意

plugins: [
 new webpack.HotModuleReplacementPlugin(),
 new webpack.NamedModulesPlugin(),
 ],

这个时候再启动。

这样名称就直观了。但是我们期待的更新还是没有出来。因为需要实现一个接口

import component from './component';
let demoComponent=component();
document.body.appendChild(demoComponent);
//HMR 接口
if(module.hot){
 module.hot.accept('./component',()=>{
 const nextComponent=component();
 document.body.replaceChild(nextComponent,demoComponent);
 demoComponent=nextComponent;
 })
}

并修改component.js:

export default function () {
 var element = document.createElement('h1');
 element.innerHTML = 'Hello webpack';
 return element;
}

这个时候页面更新了。每次改动页面上都会增加一个带有hot-update.js ,类似于下面这样:

webpackHotUpdate(0,{
/***/ "./app/component.js":
/***/ (function(module, __webpack_exports__, __webpack_require__) {
"use strict";
Object.defineProperty(__webpack_exports__, "__esModule", { value: true });
/* harmony default export */ __webpack_exports__["default"] = function () {
 var element = document.createElement('h1');
 element.innerHTML = 'Hello web ';
 element.className='box';
 return element;
};
/***/ })
})

通过webpackHotUpdate对相应模块进行更新。0表示模块的id,"./app/component.js"表示模块对应的name。结构是webpack(id,{key:function(){}})。function外带了一个括号,不知道有什么作用。webpackHotUpdate的定义是这样的:

this["webpackHotUpdate"] = 
 function webpackHotUpdateCallback(chunkId, moreModules) { // eslint-disable-line no-unused-vars 
 hotAddUpdateChunk(chunkId, moreModules);
 if(parentHotUpdateCallback) parentHotUpdateCallback(chunkId, moreModules);
 } ;

相信看了本文案例你已经掌握了方法,更多精彩请关注Gxl网其它相关文章!

推荐阅读:

JS做出数组遍历方式汇总以及性能对比

vue select操作组件开启

热心网友 时间:2022-05-14 23:17

确实,每次打包从入口开始,会parse所有的依赖,多的时候竟然打包一次要2秒多,简直不能忍。然而,有几个解决方案,最有效的,是使用weboack的watch,只有文件md5变化时,才会重新打包,并且只parse有变化的文件,其他没变化的文件是使用缓存的。这样子,打包时间迅速降到200ms以内。再优化下去的话,我们要知道webpack打包的过程中做了啥,首先是解析依赖啦,然后就是各种各样的loader。从解析依赖的角度入手,我们可以bowerinstall一些打包好的文件,然后通过设置别名让依赖指向这个文件,这样就减去了第三方库的依赖解析时间。然后各种各样的loader也是很耗时的,一种法是在loader里面配include,让loader只针对特殊资源。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
可以用电高压锅做蛋糕吗 蛋糕机选哪家实惠? 京东闪付开通后无法添加到applepay怎么办 二年级数学说课稿范文 苹果手机电充到80就不充了怎么回事 上有八,下有八中间有个十字花打一字 ...排名22000.能否上到广工的机械制造和自动化(卓越工程师班)_百度知 ... 把内存由DDR2升级到DDR3,是不是要设置什么东东啊。 怎样吧DDR2的内存条改成DDR3 ...的内存条是DDR2的,我想换DDR3的可以吗?该怎么换?还有该注意什么... “主题党日”计划安排表 开展主题党日活动是在什么情景下产生 主题党日活动制度 主题党日活动多久一次? 怎么能打开手机后壳放入手机卡? 移动a5怎样拆开后盖,安装上手机卡? 关于主题党日的活动有哪些? 手机后盖拆卸之后装上要打胶吗? oppo r809t手机后盖怎么安上啊? 手机拆后盖装回去要打胶吗? 苹果手机后盖拆下来怎么装上去呀,急急急!!! 手机后盖是胶粘式的,拆开后用买的手机后盖专用胶也粘不上了怎么办? 手机后盖打开了怎么还原 华为m20怎么装后盖 手机后部的壳拿下来按不上去怎么办? 剧本杀成90后00后社交新潮流,你玩过剧本杀吗? - 信息提示 00后步入的是一个怎样的社会? 60后那英玩00后造型,穿花衬衫戴长耳坠,效果一目了然,你怎么看? 00后靠自己赚百万的多么? 如何用webpack实现自动化的前端构建工作流 webpack打包的CSS含有两个相同的引入? webpack启动热刷新后,React为什么报错 vscode运行react项目每次更改完代码后都需要重新npm start? hot module replacement enabled.是什么意思 红烧大块鱼怎么做好吃 红烧大块腊肉的做法,红烧大块腊肉怎么做好吃 红烧大块鸡腿怎么做 红烧大块鱼的做法,红烧大块鱼怎么做好吃,红烧 学校食堂里的红烧肉(大块)的那种叫什么肉啊。。怎么烧啊 需要哪些调料啊 vivox20录像有杂音怎么办? 中国电子商务研究中心的介绍 我国电子商务的现状分析? 中国电子商务发展的现状与趋势? 中国电子商务研究中心是一个什么性质的机构 我国企业电子商务发展现状、存在的问题及解决对策研究? 我国电子商务的发展现状 我国电子商务发展现状分析,论述 中国电子商务发展存在的问题 中国电子商务发展概况