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

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

相关推荐
onebyte8bits4 分钟前
前端国际化(i18n)体系设计与工程化落地
前端·国际化·i18n·工程化
C澒13 分钟前
前端分层架构实战:DDD 与 Clean Architecture 在大型业务系统中的落地路径与项目实践
前端·架构·系统架构·前端框架
BestSongC17 分钟前
行人摔倒检测系统 - 前端文档(1)
前端·人工智能·目标检测
0思必得01 小时前
[Web自动化] Selenium处理滚动条
前端·爬虫·python·selenium·自动化
Misnice1 小时前
Webpack、Vite、Rsbuild区别
前端·webpack·node.js
青茶3601 小时前
php怎么实现订单接口状态轮询(二)
前端·php·接口
大橙子额2 小时前
【解决报错】Cannot assign to read only property ‘exports‘ of object ‘#<Object>‘
前端·javascript·vue.js
WooaiJava3 小时前
AI 智能助手项目面试技术要点总结(前端部分)
javascript·大模型·html5
LYFlied3 小时前
从 Vue 到 React,再到 React Native:资深前端开发者的平滑过渡指南
vue.js·react native·react.js
爱喝白开水a3 小时前
前端AI自动化测试:brower-use调研让大模型帮你做网页交互与测试
前端·人工智能·大模型·prompt·交互·agent·rag