vue3+vite实现环境变量配置~

1、作用:在Vite中,我们可以使用环境变量来管理不同环境下的配置。Vite支持使用.env文件来配置环境变量,不同的环境可以使用不同的.env文件来管理配置。

2、创建不同环境的.env文件

在vue3根目录下创建三个文件分别为.env.develoment.env.test.env.production

2.1在不同的.env文件中配置相应的环境变量

.env.develoment
TypeScript 复制代码
NODE_ENV='development'

VUE_APP_OSS_API = '/ossApi'
.env.test
TypeScript 复制代码
NODE_ENV='test'

VITE_APP_API_URL=''
.env.production
TypeScript 复制代码
NODE_ENV='production'

VITE_APP_API_URL='http://iblog.ishareread.com'

这里我们主要通过VITE_APP_API_URL变量来区分不同的环境调用不同的接口,在开发环境调用本地接口http://localhost:8000,在测试环境用mock接口,在生产环境调用真实接口。

3、在vue.config.js文件中配置baseurl。

TypeScript 复制代码
// oss上传
'/ossApi': {
   target: 'baseURL地址', // 目标服务器地址
   changeOrigin: true, // 允许改变 Origin
   ws: true,
   secure: false,
   logLevel: 'debug',
   pathRewrite: {
      '^/ossApi': '', // 重写路径,将 /ossApi 替换为空
   },
},

4、定义类型,在evn.d.ts中

TypeScript 复制代码
/**
 * 环境变量类型声明
 */
declare namespace NodeJS {
  interface Process {
    env: {
      VUE_APP_OSS_API: string;
    };
  }
}

5、api解耦中使用环境变量。

TypeScript 复制代码
const api_rul = import.meta.env.VUE_APP_OSS_API
//const VUE_APP_OSS_API = process.env.VUE_APP_OSS_API;
export function queryAutograph(params) {
  return request({
    url: `${api_rul}/oss/getSign`,
    method: 'get',
    params,
  });
}
相关推荐
じòぴé南冸じょうげん19 小时前
若依框架favicon.ico缓存更新问题解决方案:本地生效但线上未更新
前端·javascript·前端框架·html
狮子座的男孩19 小时前
js基础高级:01、数据类型(typeof、instanceof、===的使用)、数据与变量与内存(定义、赋值与内存关系、引用变量赋值、js调函数传参)
前端·javascript·经验分享·数据类型·数据与变量与内存·赋值与内存关系·引用变量赋值
Cyclo-1 天前
PDFJS 在React中的引入 使用组件打开文件流PDF
前端·react.js·pdf
椒盐螺丝钉1 天前
Vue Router应用:组件跳转
前端·javascript·vue.js
顾安r1 天前
11.20 开源APP
服务器·前端·javascript·python·css3
敲敲了个代码1 天前
CSS 像素≠物理像素:0.5px 效果的核心密码是什么?
前端·javascript·css·学习·面试
少云清1 天前
【软件测试】5_基础知识 _CSS
前端·css·tensorflow
倔强青铜三1 天前
AI编程革命:React + shadcn/ui 将终结前端框架之战
前端·人工智能·ai编程
二川bro1 天前
第57节:Three.js企业级应用架构
开发语言·javascript·架构
天外飞雨道沧桑1 天前
前端开发 Cursor MCP 提效工具配置
前端·vscode·ai编程·开发工具·cursor