当前位置: 首页 > news >正文

vue3 vite模式配置测试,开发、生产环境以及代理配置

1、首先在根目录下创建三个文本文件:.env.development,.env.production,.env.test

在这里插入图片描述

.env.development中的内容为:

// 开发环境 .env.development
NODE_ENV = 'development'
VITE_APP_MODE  = 'development'
VITE_OUTPUTDIR  = dist_dev // 打出包的名称
VITE_APP_BASE_URL  = http://www.development.com/

.env.production中的内容为:

// 生产环境 .env.production
NODE_ENV = 'production'
VITE_APP_MODE  = 'production'
VITE_OUTPUTDIR  = dist_pro // 打出包的名称
VITE_APP_BASE_URL  = http://www.production.com/

.env.test中的内容为:

// 测试环境 .env.test
NODE_ENV = 'test'
VITE_APP_MODE = 'test'
VITE_OUTPUTDIR = dist_test
VITE_APP_BASE_URL = http://www.test.com/

2、package.json中的script中的内容配置如下:

  "scripts": {"dev": "vite","prod": "vite --mode production","test": "vite --mode test","build": "vite build","preview": "vite preview","build:dev": "vite build --mode development","build:prod": "vite build --mode production","build:test": "vite build --mode test"},

在这里插入图片描述

3、使用:在main.js中打印查看结果:

console.log('import.meta.env.BASE_URL',import.meta.env.BASE_URL)  // 输出的为:/
console.log('import.meta.env.NODE_ENV',import.meta.env.NODE_ENV)  // 输出的为:/
console.log('import.meta.env.VITE_APP_MODE',import.meta.env.VITE_APP_MODE)  // 输出的为:/
console.log('import.meta.env.VITE_OUTPUTDIR',import.meta.env.VITE_OUTPUTDIR)  // 输出的为:/
console.log('import.meta.env.VITE_APP_BASE_URL',import.meta.env.VITE_APP_BASE_URL)  // 输出的为:/

在这里插入图片描述

4、验证:分别运行 npm run dev, npm run test、 npm run prod

在这里插入图片描述

  • npm run dev:输出结果如下:
    在这里插入图片描述
  • npm run test:输出结果如下:
    在这里插入图片描述
  • npm run prod:输出结果如下:
    在这里插入图片描述

5、可以看出以上结果会根据运行命令的不同而使用不同的配置这样就可以在生产和测试接口路径不一样时不用根据不同的命令来访问不同的接口地址,访问配置如下:

5.1、首先需要下载axios

5.2、创建如下文件及文件夹

在这里插入图片描述

5.3、http.js中的内容如下:

// axios基础的封装
import axios from 'axios'
const httpInstance = axios.create({baseURL: import.meta.env.VITE_APP_BASE_URL,timeout: 5000
})// axios请求拦截器
httpInstance.interceptors.request.use(config => {// 1. 从pinia获取token数据return config
}, e => Promise.reject(e))// axios响应式拦截器
httpInstance.interceptors.response.use(res => res.data, e => {// 统一错误提示return Promise.reject(e)
})export default httpInstance

5.4、在app.vue中发送请求并

在这里插入图片描述

import request from '@/utils/http'
request({url: `/api/member/order`
})

6、分别运行并测试

6.1 npm run test

在这里插入图片描述

6.2 npm run prod

strict-origin-when-cross-origin 出现这个需要找后端解决跨域
在这里插入图片描述

6.3 npm run dev

在这里插入图片描述

7 另一种通过代理方式:

首先需要将这三个文件中的这个东西注释掉
在这里插入图片描述
然后修改 vite.config.js 其中的内容如下:

import { fileURLToPath, URL } from 'node:url'import {defineConfig, loadEnv} from 'vite'
import vue from '@vitejs/plugin-vue'
// https://vitejs.dev/config/
export default defineConfig(({ command, mode }) => {const env = loadEnv(mode, './');  // 注意:loadEnv来自vite// console.log("env.VITE_APP_BASE_URL", env.VITE_APP_BASE_URL);return{plugins: [vue(),],resolve: {alias: {'@': fileURLToPath(new URL('./src', import.meta.url))}},// 主要修改在这server: {  proxy: {"/api": {target: env.VITE_APP_BASE_URL,// target: "",//其他配置...rewrite: (path) => path.replace(/^\/api/, ''),},},}}
})

在app.vue中发送请求

在这里插入图片描述

添加完代理后的三种方式的执行结果都是一样的

npm run dev
在这里插入图片描述

http://www.lryc.cn/news/447520.html

相关文章:

  • 【rabbitmq-server】安装使用介绍
  • Kafka系列之:安装部署CMAK,CMAK管理大型Kafka集群参数调优
  • c语言200例 64
  • [leetcode]216_组合总和III_给定数字范围且输出无重复
  • Doris 2.x 安装及使用
  • MySQL字符集设置
  • 深度学习模型量化
  • 红黑树和B+树
  • debian 12配置固定ip
  • OceanBase技术解析: 执行器中的自适应技术
  • Spring Cloud Gateway接入WebSocket:实现实时通信
  • linux信号| 学习信号三步走 | 学习信号需要打通哪些知识脉络?
  • Java调用第三方接口、http请求详解,一文学会
  • windows10使用bat脚本安装前后端环境之redis注册服务
  • fastapp-微信开发GPT项目第一课
  • 在双十一必买的好物有哪些?2024年双十一好物清单分享
  • 避免glibc版本而报错,CentOS等Linux安装node.js完美方法
  • elasticsearch实战应用
  • STM32精确控制步进电机
  • Qemu开发ARM篇-5、buildroot制作根文件系统并挂载启动
  • 光控资本:10转10送10股有多少股?转股与送股又什么区别?
  • 【音乐格式转换攻略】6个好用的音乐转换成mp3格式技巧!
  • 蓝桥杯15届C/C++B组省赛题目
  • 感悟:糟糠之妻不下堂和现在女性觉醒的关系
  • Linux网络之UDP与TCP协议详解
  • K8S:开源容器编排平台,助力高效稳定的容器化应用管理
  • STM32嵌入式编程学习到提高:【4】UART串口打印
  • C 标准库 - <ctype.h>
  • linux:chown用法详解
  • 介绍GPT-o1:一系列解决困难问题( science, coding, and math )的推理模型