WXT浏览器插件开发中文教程(24)----ES 模块支持

前言

大家好,我是倔强青铜三 。是一名热情的软件工程师,我热衷于分享和传播IT技术,致力于通过我的知识和技能推动技术交流与创新,欢迎关注我,微信公众号:倔强青铜三。欢迎点赞、收藏、关注,一键三连!!!

ES 模块 [​](#ES 模块 "#es-modules")

您的源代码应始终以 ES 模块的形式编写。不过,您可以选择是否将入口点打包为 ES 模块。

HTML页面

Vite 仅支持从 HTML 页面打包 JavaScript 为 ES 模块。请确保您的 <script> 标签中添加了 type="module"

html 复制代码
- <script src="./main.ts"></script> 
+ <script src="./main.ts" type="module"></script> 

背景脚本

默认情况下,背景脚本将被打包为单个文件的 IIFE。您可以通过在背景入口点中设置 type: "module" 来更改此行为:

ts 复制代码
export default defineBackground({
  type: 'module', 
  main() {
    // ...
  },
});

这将把输出格式改为 ES 模块,启用背景脚本和 HTML 页面之间的代码分割,并在清单文件中设置 "type": "module"

警告

仅 MV3 支持 ES 模块背景脚本/服务工作线程。当目标为 MV2 时,type 选项将被忽略,背景脚本始终被打包为单个文件的 IIFE。

内容脚本

WXT 尚未内置支持将内容脚本打包为 ES 模块。计划是添加对代码块的支持以减小打包体积,但暂时不支持 HMR。由于存在一些技术问题,实现 HMR 的通用解决方案是不可能的。详情请参阅 Content Script ESM Support #357

如果您无法等待,需要立即使用 ES 模块支持,您可以手动实现 ES 模块支持。请参阅 ESM Content Script UI 示例以了解如何操作。

最后感谢阅读!欢迎关注我,微信公众号倔强青铜三。欢迎点赞收藏关注,一键三连!!!

相关推荐
小高0072 分钟前
🚨 2025 最该淘汰的 10 个前端 API!
前端·javascript·面试
一枚前端小能手4 分钟前
🎨 页面卡得像PPT?浏览器渲染原理告诉你性能瓶颈在哪
前端·javascript
lssjzmn12 分钟前
性能飙升!Spring异步流式响应终极指南:ResponseBodyEmitter实战与架构思考
java·前端·架构
毕设源码-郭学长17 分钟前
【开题答辩全过程】以 基于vue在线考试系统的设计与实现为例,包含答辩的问题和答案
前端·javascript·vue.js
詩句☾⋆᭄南笙22 分钟前
初识Vue
前端·javascript·vue.js
Javian1 小时前
浅谈前端工程化理解
前端
艾小码1 小时前
新人必看!3天啃下大型前端项目,我是这样做到的
前端
袁煦丞1 小时前
宝塔FTP远程文件管理+安全防护:cpolar内网穿透实验室第417个成功挑战
前端·程序员·远程工作
三十_1 小时前
【NestJS】构建可复用的数据存储模块 - 动态模块
前端·后端·nestjs
干就完了11 小时前
js数组方法,其实也就这么多东西,一篇全搞懂
前端·javascript