VUE3配置后端地址,实现前后端分离及开发、正式环境分离

新建.env.development.env.production

  • .env.development 指定开发环境地址
  • .env.production 指定生产环境地址

格式如下

bash 复制代码
VITE_APP_BASE_API=http://localhost:8070

只需要在对应文件写入对应的后端地址即可

修改env.d.ts

typescript 复制代码
/// <reference types="vite/client" />
interface ImportMetaEnv {
    readonly VITE_API_BASE_URL: string;
    readonly VITE_BACKEND_BASE_URL: string; // 定义后端地址
    readonly VUE_APP_BASE_API: string // 定义后端API接口地址
    // 其他环境变量
}

interface ImportMeta {
    readonly env: ImportMetaEnv;
}

修改vite.config.ts

具体看注释即可

typescript 复制代码
import { fileURLToPath, URL } from 'node:url'
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import vueDevTools from 'vite-plugin-vue-devtools'

// https://vite.dev/config/
// 导出一个默认的配置对象,用于配置当前项目
export default defineConfig({
  // 插件配置,加载 vue 和 vueDevTools 插件
  plugins: [
    vue(),
    vueDevTools(),
  ],
  // 解析配置,用于配置模块导入路径的别名
  resolve: {
    alias: {
      // 将 '@' 符号映射到项目的 src 目录,简化导入路径
      '@': fileURLToPath(new URL('./src', import.meta.url))
    },
  },
  // 基本配置,定义项目的基路径
  base: '/',
  // 服务器配置,用于开发服务器的设置
  server: {
    // 代理配置,解决开发环境下的跨域问题
    proxy: {
      // 将以 '/api' 开头的请求代理到后端服务器
      '/api': {
        // 后端服务器地址,使用环境变量
        target: import.meta.env.VITE_APP_BASE_API,
        // 允许改变请求的来源
        changeOrigin: true,
        // 重写请求路径,去掉 /api 前缀
        rewrite: (path) => {
          const newPath = path.replace(/^\/api/, '');
          console.log(`Original path: ${path}, Rewritten path: ${newPath}`);
          return newPath;
        },
      },
    },
  },
});

使用

通过package.json运行的时候,选择dev即可让程序自动走.env.development定义的后端地址,选择build即走生产环境的后端地址

相关推荐
代码or搬砖20 小时前
flask与vue实现通过websocket通信
vue.js·websocket·flask
Mike_jia20 小时前
LogWhisperer 全解析:打造你的Linux服务器AI日志分析中枢
前端
网安Ruler20 小时前
崭新出厂,自研CipherForge小工具,攻破 D-Link M30 固件加密
前端·网络·python
daxiang1209220520 小时前
记一次前端请求报错:Content-Length can‘t be present with Transfer-Encoding,+Cursor使用教训
前端·cursor
武清伯MVP20 小时前
深入了解Canvas:HTML5时代的绘图利器(二)
前端·html5·canvas
float_六七20 小时前
Spring AOP表达式速查手册
前端·javascript·spring
PineappleCoder20 小时前
没 CDN = 用户等半天?四大核心机制:就近、分流、提速、容错全搞定
前端·性能优化
DsirNg20 小时前
JavaScript 事件循环机制详解及项目中的应用
开发语言·javascript·ecmascript
suoyue_zhan20 小时前
GBase 8s V8.8 安装部署实践指南
前端·数据库·chrome
LisEcho20 小时前
yoyoj-rn — RN 的脚手架工具可以不是 @react-native-community/cli
前端·react native·npm