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 文件被加载到进程中。

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

相关推荐
问心无愧05134 小时前
ctf show web入门160 161
前端·笔记
李小白664 小时前
第四天-WEB服务器基本原理,IIS服务
运维·服务器·前端
humcomm5 小时前
AI编程时代新前端职位
前端·ai编程
好家伙VCC5 小时前
Web Components主题热切换方案揭秘
java·前端
甲维斯6 小时前
Kimi版超级玛丽效果“惊人”,配额不足5厘米!
前端·人工智能
hboot6 小时前
AI工程师第一课 - Python
前端·后端·python
凉菜凉凉6 小时前
AI时代,被抛弃的前端
前端·ai
console.log('npc')6 小时前
AI前端工程与生成式UI学习路线
前端·人工智能·ui
huangdong_6 小时前
淘宝商品SKU图自动分类技术深度解析:从DOM解析到智能归档
开发语言·javascript·ecmascript
梦曦i6 小时前
uni-router v1.1.1发布:守卫超时保护+路由监听
前端·uni-app