西安有关做网站的公司,雅奇小蘑菇做网站好不好用,鹰潭市住房和城乡建设局网站,营销型网站建设公司哪家好哪个好HMR全称Hot Module Replacement#xff0c;可以理解为模块热替换#xff0c;指在应用程序运行过程中#xff0c;替换、添加、删除模块#xff0c;而无需重新刷新整个应用。
不使用热更新#xff0c;我们在应用运行过程中修改了某个模块#xff0c;通过自动刷新会导致整个…HMR全称Hot Module Replacement可以理解为模块热替换指在应用程序运行过程中替换、添加、删除模块而无需重新刷新整个应用。
不使用热更新我们在应用运行过程中修改了某个模块通过自动刷新会导致整个应用的整体刷新那页面中的状态信息都会如果使用的是HMR就可以实现只将修改的模块实时替换至应用中只会重新编译修改的代码将新的模块发送到客户端替换掉旧的模块不必完全刷新整个应用。
实现 HMR 的关键是在客户端和服务器端之间建⽴⼀个 WebSocket 连接当代码发⽣变化 时服务器端会将新的模块发送给客户端客户端接收到新的模块后会⽤新模块替换旧模块从⽽实现实时更新。 const webpack require(webpack)module.exports {// ...devServer: {// HMR hot: true// hotOnly: true}}具体来说webpack HMR 主要分为以下⼏个步骤
webpack-dev-server 将打包输出 bundle 。每当文件发生变更时webpack 将会重新编译webpack-dev-server 将会监控到此时文件变更事件并找到其对应的 module。webpack-dev-server 将会把变更模块通知到浏览器端此时使用 websocket 与浏览器进行交流。浏览器根据 websocket 接收到 hash并通过 hash 以 JSONP 的方式请求更新模块的 chunk。浏览器加载 chunk并使用新的模块对旧模块进行热替换并删除其缓存。