本文主要是介绍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"breakcase 'prod': //生产baseUrl = "http://xxxx"breakdefault://本地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"},
这篇关于vue 不同环境打包指令的配置(vue-cli2、vue-cli3、vite)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!