vue 不同环境打包指令的配置(vue-cli2、vue-cli3、vite)

一个项目可能会有开发版本、上线版本、测试版本等等多个版本,不同的环境会有不同请求api接口,就需更改一些基本配置,这时候为不同环境配置不同的打包指令就很必要。

一、vue-cli2

1、安装 cross-env,它可以处理 windows 和其他 Unix 系统在设置环境变量的写法上不一致的问题。

复制代码
npm i --save-dev cross-env

2、配置不同环境下的文件和参数,在 config 目录下创建test.env.js、prod.env.js、dev.env.js 文件并修改文件内容:

test.env.js:测试环境

复制代码
'use strict'
module.exports ={ 
  NODE_ENV: '"test"',
  EVN_CONFIG:'"test"',
  API_ROOT: '"xxx"'
}

prod.env.js:生产环境

复制代码
'use strict'
module.exports = { 
 NODE_ENV: '"production"',
 EVN_CONFIG:'"prod"',
 API_ROOT:'"xxx"'
}

API_ROOT 是后端接口服务IP或者域名。

3、打开 package.json 文件,在 scripts 里面配置指令名称

复制代码
"scripts": { 
    "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js",
    "start": "npm run dev",
    "build": "node build/build.js",
    "build:test": "cross-env NODE_ENV=test env_config=test node build/build.js",
    "build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js",
  }

4、打开 config / index.js 文件,在 build 最上面添加 prodEnv、testEnv,这里的参数会在build/webpackage.prod.conf.js中使用到

复制代码
build: { 
    prodEnv: require('./prod.env'),
    testEnv: require('./test.env'),
    index: path.resolve(__dirname, '../dist/index.html'),
 }
 //下面内容不需要修改

5、打开 build/webpackage.prod.js 文件,调整env常量的生成方式

复制代码
//仅修改 env 
const env = config.build[process.env.env_config+'Env'];
//process.env.env_config+'Env' ==> prodEnv、testEnv

6、打开 build / build.js 文件,修改 spinner 的定义

复制代码
'use strict'
require('./check-versions')()
//process.env.NODE_ENV = 'production'
const ora = require('ora')
const rm = require('rimraf')
const path = require('path')
const chalk = require('chalk')
const webpack = require('webpack')
const config = require('../config')
const webpackConfig = require('./webpack.prod.conf')
//const spinner = ora('building for production...')
var spinner = ora('building for ' + process.env.NODE_ENV + ' of ' + process.env.env_config+ ' mode...' )
spinner.start()
//下面内容不需要修改

7、打包

复制代码
//测试环境打包
npm run build:test
//生产环境打包
npm run build:prod
二、vue-cli3

1、在 package.json 文件配置指令名称

复制代码
"scripts": { 
    "dev": "vue-cli-service serve",
    "build": "vue-cli-service build",
    "build:test": "vue-cli-service build --mode test",
    "build:prod": "vue-cli-service build --mode prod"
  }

2、在 package.json 同级目录下创建 .env.test、.env.prod 文件,以及 config.js 文件,然后修改文件里的内容

.env.test:测试环境

复制代码
NODE_ENV = 'test'
VUE_APP_TITLE = 'test'

.env.prod :生产环境

复制代码
NODE_ENV = 'prod'
VUE_APP_TITLE = 'prod'

特别注意:

NODE_ENV = 'prod' 和 VUE_APP_TITLE = 'prod'这个后面千万不要加 " ; " 如果加了你在获取 process.env.VUE_APP_TITLE的时候获取到的是 'prod'; ,在环境判断的时候将会是很大的问题。

config.js:配置不同环境下对应的接口域名

复制代码
let baseUrl = ''
switch (process.env.VUE_APP_TITLE) { 
    case 'test': //测试
        baseUrl = "http://xxxx"
        break
    case 'prod': //生产
        baseUrl = "http://xxxx"
        break
    default://本地
        baseUrl = "http://xxxxt"
}
export default baseUrl;
三、vite

1, 在 package.json 同级目录下创建 .env.test、.env.prod 文件,修改文件里的内容

.env.tese 测试环境

复制代码
MODE = 'test'
VITE_APP_API=***

.env.prod 生产环境

复制代码
MODE =production
VITE_APP_API='***'

2.在 package.json 文件配置指令名称

复制代码
"scripts": {
    "dev": "vite",
    "build": "npm run build:prod",
    "build:prod": "vue-tsc --noEmit && vite build --mode production",
    "build:test": "vue-tsc --noEmit && vite build --mode test",
    "build:lpt": "vue-tsc --noEmit && vite build --mode lpt",
    "build:dev": "vue-tsc --noEmit && vite build --mode development",
    "serve": "npm run build && vite preview",
    "lint": "eslint \"src/**/*.{vue,ts}\" --fix"
  },
相关推荐
工业甲酰苯胺3 小时前
TypeScript枚举类型应用:前后端状态码映射的最简方案
javascript·typescript·状态模式
brzhang3 小时前
我操,终于有人把 AI 大佬们 PUA 程序员的套路给讲明白了!
前端·后端·架构
止观止3 小时前
React虚拟DOM的进化之路
前端·react.js·前端框架·reactjs·react
goms3 小时前
前端项目集成lint-staged
前端·vue·lint-staged
谢尔登4 小时前
【React Natve】NetworkError 和 TouchableOpacity 组件
前端·react.js·前端框架
Lin Hsüeh-ch'in4 小时前
如何彻底禁用 Chrome 自动更新
前端·chrome
augenstern4166 小时前
HTML面试题
前端·html
张可6 小时前
一个KMP/CMP项目的组织结构和集成方式
android·前端·kotlin
G等你下课6 小时前
React 路由懒加载入门:提升首屏性能的第一步
前端·react.js·前端框架
谢尔登7 小时前
【React Native】ScrollView 和 FlatList 组件
javascript·react native·react.js