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 示例以了解如何操作。

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

相关推荐
dllxhcjla21 小时前
css第二天
java·前端·css
BBB努力学习程序设计21 小时前
让数据阅读更轻松:隔行换色表格的妙用
前端·html
LateFrames21 小时前
使用 Winform / WPF / WinUI3 / Electron 实现异型透明窗口
javascript·electron·wpf·winform·winui3
码农刚子21 小时前
ASP.NET Core Blazor 核心功能二:Blazor表单和验证
前端·html
BBB努力学习程序设计21 小时前
细线表格:打造优雅的数据展示界面
前端·html
前端老宋Running21 小时前
为什么react~Hooks只能在组件最顶层调用
前端·react.js·面试
Asort21 小时前
React类组件精要:定义机制与生命周期方法进阶教程
前端·javascript·react.js
陳陈陳21 小时前
从“变量提升”到“调用栈爆炸”:V8 引擎是如何偷偷执行你的 JavaScript 的?
javascript
祈祷苍天赐我java之术21 小时前
SpringCache :让缓存开发更高效
前端·spring·bootstrap
Tonyzz21 小时前
开发编程进化论:openspec的魔力
前端·ai编程·vibecoding