vite - 设置不同环境的打包命令及配置

原由:同一套业务逻辑的代码需要根据使用的地区不同,同一个位置的显示内容会发生改变

想法:打包时根据不同的命令获取其所设置的环境参数内容

基本信息

备注:默认情况下模式都会被覆盖掉,可以使用--mode改写(文档

json 复制代码
-- package.json -- 

"build": vite build // 一般情况下打包正式环境的命令 => vite build -- mode production

其对应的环境是production生产环境,对应的配置文件名称为.env.production

例子:以创建中国地区内容为例

  1. 根目录下创建配置文件为.env.production.china
  2. package.json补充打包命令
json 复制代码
-- package.json -- 

"build": vite build // 一般情况下打包正式环境的命令 == vite build -- mode production
+ "build:china": vite build --mode production.china
  1. 编写配置文件内容

为了防止意外地将一些环境变量泄漏到客户端,只有以 VITE_ 为前缀的变量才会暴露给经过 vite 处理的代码

javascript 复制代码
-- .env.production.china --

VITE_APP_TITLE=中国地区

VITE_PHONE=86-123456789
javascript 复制代码
-- .env.production --

VITE_APP_TITLE=海外地区

VITE_PHONE=xx-123456789

使用一、html文件的title设置

  1. 安装插件
cmd 复制代码
npm i vite-plugin-html
  1. 在配置文件中设置
javascript 复制代码
-- vite.config.js --

import { defineConfig, loadEnv } from 'vite';
// 引入插件
import { createHtmlPlugin } from 'vite-plugin-html'

export default defineConfig(({ command, mode }) => ({
  plugins: [
    createHtmlPlugin({
      inject: {
        data: {
          // 设置标题
          title: loadEnv(mode, process.cwd())[VITE_APP_TITLE]
        }
      }
    })
  ],
}))
  1. index.html中使用
html 复制代码
<title><%- title %></title>

使用二、单页面应用中设置

vue 复制代码
<template>
 {{ phone }}
</template>

<script setup>
import { computed } from 'vue';

const envConfig = import.meta.env;
const phone = computed(() => envConfig.VITE_PHONE)
</script>

打包

对应的环境就运行对应环境的命令即可

参考链接

  1. 官网(环境变量与模式):www.vitejs.net/guide/env-a...
相关推荐
Z兽兽20 分钟前
React@18+Vite项目配置env文件
前端·react.js·前端框架
SuniaWang27 分钟前
《Spring AI + 大模型全栈实战》学习手册系列 · 专题六:《Vue3 前端开发实战:打造企业级 RAG 问答界面》
java·前端·人工智能·spring boot·后端·spring·架构
A_nanda1 小时前
根据AI提示排查vue前端项目
前端·javascript·vue.js
happymaker06262 小时前
web前端学习日记——DAY05(定位、浮动、视频音频播放)
前端·学习·音视频
~无忧花开~2 小时前
React状态管理完全指南
开发语言·前端·javascript·react.js·前端框架
LegendNoTitle2 小时前
计算机三级等级考试 网络技术 选择题考点详细梳理
服务器·前端·经验分享·笔记·php
@大迁世界2 小时前
1.什么是 ReactJS?
前端·javascript·react.js·前端框架·ecmascript
BJ-Giser3 小时前
Cesium 基于EZ-Tree的植被效果
前端·可视化·cesium
王码码20354 小时前
Flutter for OpenHarmony:Flutter 三方库 algoliasearch 毫秒级云端搜索体验(云原生搜索引擎)
android·前端·git·flutter·搜索引擎·云原生·harmonyos
发现一只大呆瓜4 小时前
深入浅出 AST:解密 Vite、Babel编译的底层“黑盒”
前端·面试·vite