利用webpack实现对html文件的热更新

本文介绍了如何在webpack中实现html文件的热更新。通过webpack-dev-server和html-webpack-plugin插件,以及配合raw-loader,详细阐述了两种实现html热更新的方法,确保在代码修改后无需手动刷新页面即可看到效果。

       webpack中webpack-dev-server是一个简单的web服务器,可以帮助我们实现代码的热更新,即在实际开发中只需保存修改完后的代码,不用手动刷新页面就可以看到效果。在使用webpack-dev-server时,会发现在对js、css文件中的代码修改时,可以很容易地实现页面热更新;修改html文件内容时,保存代码,页面并没有自动更新。(可以在html-hot-reload项目的中demo1分别修改html、js、css文件试一试)。

       这是因为webpack在运行时它会根据webpack.config.js中入口文件(entry)来开始查询所有的依赖并根据不同的处理器(loader)、插件(plugin)来解析、打包,webpack-dev-server会实时监控webpack打包后的文件并实现热更新。js、css文件很容易实现热更新是因为js文件一般为入口文件或者js文件、css文件与入口文件存在依赖关系,在webpack打包后受到webpack-dev-server的实时监控。由于html与入口文件不存在依赖关系,所以实现不了热更新。可以通过以下两种方法实现对html文件热更新。

方法一:利用html-webpack-plugin插件

html-webpack-plugin插件就是在webpack打包时重新生成一个html文件

(可以在html-hot-reload项目的中demo2中分别修改html、js、css文件查看效果)

1、安装html-webpack-plugin插件

npm install --save-dev html-webpack-plugin

 2、在webpack.config.js中配置html-webpack-plugin插件

......
const htmlWebpackPlugin = require('html-webpack')

module.exports = {
  ......
  plugins: [
    new htmlWebpackPlugin({
      template: './index.html'
    })
  ]
  ......
}

方法二:在入口文件中引入html文件,并使用raw-loader对html文件进行处理,实现html热更新

在入口文件中引入html文件是为了让html与入口文件产生依赖,这样在webpack运行时可以打包处理html文件。

(可以在html-hot-reload项目的中demo3中分别修改html、js、css文件查看效果)

1、安装raw-loader

npm install --save-dev raw-loader

2、在webpack.config.js中配置raw-loader

module.exports = {
  ......
  module: {
    rules: [
      ......
      {
         test: /\.(htm|html)$/,
         use: [
           'raw-loader'
         ]
      }
      ......
    ]
  }
  ......
}

3、在入口文件index.js文件中引入index.html文件

import '../index.html'

       综上所述,利用以上两种方法,我们可以在webpack搭建的环境中实现对html文件的热更新。可以参考html-hot-reload项目中的代码进行学习理解。

评论 5
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值