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)
打印结果
总结
来源:https://blog.csdn.net/weixin_45547638/article/details/127277857


猜你喜欢
- 本文实例讲述了js对象基础用法。分享给大家供大家参考。具体分析如下:js对象在本质上与数组相同,都是存放一组数据。但创建方法有所不同,对象需
- 昨天对其配置了一天,其配置为Jena 2.4.0,MySQL数据库版本为5.1.42-community,JDK版本为1.6.0,MySQL
- 1、文件添加方式:pycharm提供了一个在新建文件自动生成文件头注释的功能,可以实现自动生成运行环境,作者、日期等必要信息,使用比较方便,
- 在将数据库从MSSQL迁移到MySQL的过程中,基于业务逻辑的要求,需要在MySQL的自增列插入0值。在MSSQL中是这样完成的: stri
- 1.0 新建项目1.1 初始化项目输入npm init,之后需要填什么就写什么新建src目录,并在src目录下新建alert.vue$ np
- 想实现发送邮件需要经过以下几步:1、登录邮件服务器2、构造符合邮件协议规则要求的邮件内容3、发送Python对SMTP支持有smtplib和
- 背景:现如今不管什么服务和应用基本都可以在docker里跑一跑了,但是在我个人的印象中,像数据库这种比较重要大型且数据容易受伤的应用是不适合
- 为了网站的安全,肯定不让上传php文件,如果有人进入你的后台,上传了一个php文件,你的网站源码,全部救变成他的了,直接打包看你的代码。所以
- 继上一篇计算checksum校验和,本章通过socket套接字,struct字节打包成二进制,select返回套接字的文件描述符的结合,实现
- 本文实例讲述了Python利用正则表达式匹配并截取指定子串及去重的方法。分享给大家供大家参考。具体如下:import repattern=r
- 我首次用mysql是在ubuntu上,现在用的是linux 中的Red Hat 分支的centOS 7 ,安装时发现通常用的都是MariaD
- 一、Linux系统查看Python路径whereis python此命令将会列出系统所安装的所有版本的Python的路径效果如下: 
- 从MySQL 5.0.2开始,通过mysql_stmt_attr_set() C API函数实现了服务器端光标。服务器端光标允许在服务器端生
- 今天在调试项目的时候出现下面的错误信息:SoapFaultlooks like we got no XML document (D:\php
- 四兄弟的背景在一个名为编程语言的村庄里,有不同姓氏的村民。例如Java、Python、Golang、JavaScript等姓氏,而接下来要介
- 前一段时间就安装了AspJpeg 2.0,一直没有时间去测试,直到昨天晚上因为服务器无法访问才在本机测试下,特分享下测试结果,只针对GIF图
- 1. 前言 本文介绍一个贝叶斯推断的pytho
- 需求每天往一个表里面插入两条数据,但日期不同INSERT INTO test(`id`, `art_training_institution
- 一、初识正则表达式正则表达式 是一个特殊的字符序列,一个字符串是否与我们所设定的这样的字符序列,相匹配快速检索文本、实现替换文本的操作jso
- 来自Usability Post的Categories vs Tags作者认为“就博客而言,标签没有太大意义。”I don’t think