WXT浏览器插件开发中文教程(6)----WXT配置详解之环境变量

前言

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

环境变量

Dotenv 文件 [​](#Dotenv 文件 "#dotenv-%E6%96%87%E4%BB%B6")

WXT 以与 Vite 相同的方式支持 dotenv 文件。可以创建以下文件:

plaintext 复制代码
.env
.env.local
.env.[mode]
.env.[mode].local
.env.[browser]
.env.[browser].local
.env.[mode].[browser]
.env.[mode].[browser].local

在这些文件中列出的任何环境变量都将在运行时可用:

sh 复制代码
# .env
WXT_API_KEY=...
ts 复制代码
await fetch(`/some-api?apiKey=${import.meta.env.WXT_API_KEY}`);

请记住,按照 Vite 的约定,环境变量必须以 WXT_VITE_ 开头,否则它们在运行时将不可用。

内置环境变量

WXT 根据当前命令提供了一些自定义环境变量:

用法 类型 描述
import.meta.env.MANIFEST_VERSION 2 │ 3 目标清单版本
import.meta.env.BROWSER string 目标浏览器
import.meta.env.CHROME boolean 等同于 import.meta.env.BROWSER === "chrome"
import.meta.env.FIREFOX boolean 等同于 import.meta.env.BROWSER === "firefox"
import.meta.env.SAFARI boolean 等同于 import.meta.env.BROWSER === "safari"
import.meta.env.EDGE boolean 等同于 import.meta.env.BROWSER === "edge"
import.meta.env.OPERA boolean 等同于 import.meta.env.BROWSER === "opera"

您还可以访问所有 Vite 的环境变量

用法 类型 描述
import.meta.env.MODE string 扩展程序运行的 模式
import.meta.env.PROD boolean NODE_ENV='production'
import.meta.env.DEV boolean import.meta.env.PROD 的相反值

其他 Vite 环境变量

Vite 提供了另外两个环境变量,但在 WXT 项目中它们并不实用:

  • import.meta.env.BASE_URL:应使用 browser.runtime.getURL 代替。
  • import.meta.env.SSR:始终为 false

清单中使用环境变量

要在清单中使用环境变量,您需要使用函数语法:

ts 复制代码
export default defineConfig({
  extensionApi: 'chrome',
  modules: ['@wxt-dev/module-vue'],
  manifest: { 
    oauth2: { 
      client_id: import.meta.env.WXT_APP_CLIENT_ID
    } 
  } 
  manifest: () => ({ 
    oauth2: { 
      client_id: import.meta.env.WXT_APP_CLIENT_ID
    } 
  }), 
});

WXT 在加载配置文件后才能加载您的 .env 文件。因此,通过使用函数语法为 manifest 延迟创建对象,直到 .env 文件被加载到进程中。

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

相关推荐
代码搬运媛1 天前
Jest 测试框架详解与实现指南
前端
counterxing1 天前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq1 天前
windows下nginx的安装
linux·服务器·前端
之歆1 天前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜1 天前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108081 天前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
candyTong1 天前
Claude Code 的 Edit 工具是怎么工作的
javascript·后端·架构
kyriewen1 天前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm1 天前
元框架的工作原理详解
前端·前端框架
canonical_entropy1 天前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程