vue3+vite使用环境变量.env的一些配置情况详细说明

作者:一室易安 时间:2024-04-26 17:38:40 

在项目文件中新建文件.env .env.pro 两个文件其中.env 是默认设置 .env.pro 为正式环境设置

1、设置.env中的内容信息 注意vue3+vite 必须使用VITE开头的配置信息 否则无法获取

NODE_ENV = "env"//
VITE_NODE_ENV = "env"//VITE开头的给vue3+vite使用  

如果不想使用VITE开头自己修改就在vite.config.ts文件中添加envPrefix:“APP_”

//vite.config.ts
export default defineConfig({
 plugins: [vue()],
 envPrefix:"APP_",//APP_  为自定义开头名
})

2、在 vite 中使用环境变量,可以用 import.meta.env,有四种环境变量,如下所示:

MODE,用来指明现在所处于的模式,一般通过它进行不同环境的区分,比如 dev、test、pre、prd 等等,默认为:“development”

BASE_URL,用来请求静态资源初始的 url

PROD,用来判断当前环境是否是正式环境

DEV,用来与 PROD 相反的环境

SSR,用来判断是否是服务端渲染的环境

3、使用环境变量

使用 import.meta.env.VITE_NODE_ENV 获取环境变量

console.log( import.meta.env) //查看相关信息 这里不显示非VITE开头的变量

//老版本的vue2+webpack的情况

还是使用 process.env.NODE_ENV

console.log( process.env) //查看相关信息

4、配置env.d.ts文件,为环境变量增加智能提示

正常使用的时候没有提示信息,想增加提示信息在vite-env.d.ts或者env.d.ts进行如下配置即可

/// <reference types="vite/client" />

interface ImportMetaEnv {
 readonly VITE_NODE_ENV:string;//定义提示信息 数据是只读的无法被修改
 //多个变量定义多个...
}

declare module '*.vue' {
 import type { DefineComponent } from 'vue'
 const component: DefineComponent<{}, {}, any>
 export default component
}

5、在package.json中配置模式

上面使用的时候是固定写法 需要切换.env 和 .env.pro 中不同的变量信息 在打包中配置 如下:

使用 --mode pro 进行设置

"scripts": {
   "serve": "vite",//未指定默认取.env中的配置
   "dev": "vite --mode dev",   // 取 .env.dev文件中的配置
   "pro": "vite --mode pro",   // 取 .env.pro文件中的配置
   "build": "vue-tsc --noEmit && vite build",//未指定默认取.env中的配置
   "build:dev": "vue-tsc --noEmit && vite build --mode dev",    // build的时候取dev的配置
   "build:pro": "vue-tsc --noEmit && vite build --mode pro", // build的时候取pro的配置
   "preview": "vite preview"
 },

最后, 想要在提交代码时忽略本地.env文件,还要在.gitignore文件中添加.local

node_modules
dist
dist-ssr
*.local

补充:Vue3的Env环境变量配置的应用

.env(# 所有环境默认)

# 所有环境默认

# 页面 title 前缀
VUE_APP_TITLE=某某某

# 网络请求公用地址
VUE_APP_API= /

.env.development(# 开发环境)

# 开发环境

# 指定构建模式
VITE_NODE_ENV=development

# 页面 title 前缀
VUE_APP_TITLE=某某某

# 网络请求公用地址
VITE_APP_API=/api/

# 首页是否显示登录
VITE_SHOW_LOGIN='yes'

VITE_SOME_APPENV='1000006'

.env.production(# 生产环境)

# 构建预览页面

# 指定构建模式 production
VITE_NODE_ENV=test

# 页面 title 前缀
VUE_APP_TITLE=某某某

# 网络请求公用地址
VITE_APP_API=/

# 首页是否显示登录
VITE_SHOW_LOGIN='no'

VITE_SOME_APPENV='1000002'

在页面中需要参与环境判断时则可使用

console.log(import.meta.env.VITE_NODE_ENV)

打印结果

vue3+vite使用环境变量.env的一些配置情况详细说明

总结

来源:https://blog.csdn.net/weixin_45547638/article/details/127277857

标签:vite,环境变量,.env
0
投稿

猜你喜欢

  • 关于Python 实现tuple和list的转换问题

    2022-02-18 21:29:03
  • ASP读取ini文件

    2010-01-20 11:17:00
  • PyQt5每天必学之单行文本框

    2022-09-12 06:29:35
  • 深入SQL Server中定长char(n)与变长varchar(n)的区别详解

    2024-01-14 01:53:42
  • Django框架实现的简单分页功能示例

    2022-05-16 08:25:43
  • 超半数中文网页一年内将“消失”

    2008-03-08 12:49:00
  • Anaconda 查看、创建、管理和使用python环境的方法

    2023-11-29 02:34:48
  • ASP也使用ORM,给ASP上所有的SQL注入画上句号

    2011-04-03 11:02:00
  • Oracle下的Java分页功能_动力节点Java学院整理

    2024-01-20 16:34:00
  • mysql sql_mode="" 的作用说明

    2024-01-25 22:58:24
  • Django基础CBV装饰器和中间件的应用示例

    2023-09-30 06:17:07
  • anaconda如何查看并管理python环境

    2023-11-10 13:31:38
  • Python 如何创建一个简单的REST接口

    2022-03-07 17:03:16
  • 关于Pycharm配置翻译插件Translation报错更新TTK失败不能使用的问题

    2023-08-22 05:02:17
  • python+mediapipe+opencv实现手部关键点检测功能(手势识别)

    2022-04-20 17:26:05
  • python放大图片和画方格实现算法

    2023-05-21 15:22:41
  • Python中if elif else及缩进的使用简述

    2021-06-18 18:29:36
  • Go语言学习网络编程与Http教程示例

    2024-02-08 10:33:12
  • Python3实现的Mysql数据库操作封装类

    2024-01-20 23:57:36
  • MySQL数据库备份与恢复方法

    2024-01-18 08:54:10
  • asp之家 网络编程 m.aspxhome.com