Environment Variables 
Dotenv Files 
WXT supports dotenv files the same way as Vite. Create any of the following files:
.env
.env.local
.env.[mode]
.env.[mode].local
.env.[browser]
.env.[browser].local
.env.[mode].[browser]
.env.[mode].[browser].localAnd any environment variables listed inside them will be available at runtime:
# .env
WXT_API_KEY=...await fetch(`/some-api?apiKey=${import.meta.env.WXT_API_KEY}`);Remember to prefix any environment variables with WXT_ or VITE_, otherwise they won't be available at runtime, as per Vite's convention.
Built-in Environment Variables 
WXT provides some custom environment variables based on the current command:
| Usage | Type | Description | 
|---|---|---|
| import.meta.env.MANIFEST_VERSION | 2 │ 3 | The target manifest version | 
| import.meta.env.BROWSER | string | The target browser | 
| import.meta.env.CHROME | boolean | Equivalent to import.meta.env.BROWSER === "chrome" | 
| import.meta.env.FIREFOX | boolean | Equivalent to import.meta.env.BROWSER === "firefox" | 
| import.meta.env.SAFARI | boolean | Equivalent to import.meta.env.BROWSER === "safari" | 
| import.meta.env.EDGE | boolean | Equivalent to import.meta.env.BROWSER === "edge" | 
| import.meta.env.OPERA | boolean | Equivalent to import.meta.env.BROWSER === "opera" | 
You can set the targetBrowsers option to make the BROWSER variable a more specific type, like "chrome" | "firefox".
You can also access all of Vite's environment variables:
| Usage | Type | Description | 
|---|---|---|
| import.meta.env.MODE | string | The mode the extension is running in | 
| import.meta.env.PROD | boolean | When NODE_ENV='production' | 
| import.meta.env.DEV | boolean | Opposite of import.meta.env.PROD | 
Other Vite Environment Variables
Vite provides two other environment variables, but they aren't useful in WXT projects:
- import.meta.env.BASE_URL: Use- browser.runtime.getURLinstead.
- import.meta.env.SSR: Always- false.
Manifest 
To use environment variables in the manifest, you need to use the function syntax:
export default defineConfig({
  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 can't load your .env files until after the config file has been loaded. So by using the function syntax for manifest, it defers creating the object until after the .env files are loaded into the process.
Note that Vite's runtime environment variables, like import.meta.env.DEV, will not be defined. Instead, access the mode like this:
export default defineConfig({
  manifest: ({ mode }) => {
    const isDev = mode === 'development';
    console.log('Is development mode:', isDev);
    // ...
  },
});