webpack HMR的使用

热模块替换(HMR)是Webpack提供的一种优化技术,当模块发生改变时,只重新打包变动的模块,无需刷新整个页面,提高了开发效率。启用HMR可通过命令行参数`webpack-dev-server--hot`或在webpack.config.js配置。此外,开发者可以使用HMRAPI中的`module.hot.accept`来注册更新处理函数,实现特定模块更新时的定制行为。
摘要由CSDN通过智能技术生成

简介

热模块替换(HMR):如果一个模块发生变化,只会重新打包这一个模块(而不是所有模块都进行打包),而无需重新加载整个页面。

作用:

  • 提高构建速度
  • 修改文件时不用刷新页面,能够保持页面状态

启用方式

  1. 通过命令参数: webpack-dev-server --hot

  2. 通过配置文件:
    webpack.config.js

const webpack = require('webpack')
module.exports = {
	devServer: {
		hot: true,//  热更新失败时刷新浏览器
    	hotOnly: true,//  热更新失败时不刷新浏览器
	},
	plugins:[ new webpack.HotModuleReplaceMentPlugin() ]
}

HMR apis

在webpack的入口文件的module对象中有个hot属性
这个属性就是包含HMR api的核心对象
hot中有个accept函数,用于注册某个模块更新过后的处理函数(参数1)
注册过热更新处理函数的模块更新时不再自动刷新页面

module.hot.accept('./heading.js',() => {
    console.log('./heading.js update');
  })
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值