chrome浏览器插件热更新vite实战

本文介绍了如何在没有webpack的情况下,利用Vite和热更新原理为Chrome浏览器插件实现热更新功能。通过建立WebSocket连接,监听文件变化,接收到消息后执行局部或全局更新,从而提高开发效率。
摘要由CSDN通过智能技术生成

热更新,又名模块热替换:Hot Module Replacement,简称HMR,无需完全刷新整个页面的同时,更新模块。HMR主要用于提升开发体验。

页面的刷新有多种情况:页面级别的刷新,简单粗暴,但是不保留页面状态。即:window.location.reload(),
刀耕火种时代的页面更新都是采用这种方法,写完代码之后页面并不能及时看到效果。需要手动刷新页面,或者触发reload。

后来webpack提供了更为友好的开发体验,只更新局部模块,而不是刷新页面。在代码变更之后自动触发对应的更新。同时保留页面的状态(输入框的值、选择器的选中等)。
我们首先知道webpack热更新原理:

  1. dev-server和页面建立了websocket连接
  2. 监听到文件变化
  3. 通过websocket告诉页面模块发送了变化
    4.页面局部更新

想要了解更详细的可以搜webpack热更新,此处不多做赘述。
我们了解了大概原理之后,就可以在没有webpack的时候自己实现。
浏览器插件的开发在代码编写完之后需要扔到浏览器扩展应用里面才可以看到效果,并且在代码变更之后是需要手动刷新,这时候我们就没有webpack工具来给我们提供热更新的支持。

我在尝试用vite开发浏览器插件的时候,就在思考,我们可以通过热更新一样的原理去帮插件自动更新。

同样的原理:

  const ws = new WebSocket('ws://localhost:2333')
    
  ws.onmessage = (event) => {
    console.log('reload t
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Manggoo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值