vue多环境配置
时间:2021-08-12
本文章向大家介绍vue多环境配置,主要包括vue多环境配置使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。
Vue多环境配置方案的实现
一般服务器分为本地环境,测试环境,正式环境,如果每次都要修改配置就很麻烦,总结一下我使用的方法。
修改执行命令
修改package.json文件的scripts,在打包的时候执行不同的命令
测试执行那npm run build:sit
正式执行npm run build:prod
这里用到了cross-env能跨平台地设置及使用环境变量,使用
npm install cross-env --save "scripts": { "dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js", "start": "npm run dev", "build": "node build/build.js", "build:prod": "cross-env NODE_ENV=production env_config=prod node build/build.js", "build:sit": "cross-env NODE_ENV=production env_config=sit node build/build.js" },
修改配置文件
修改vue项目下config文件夹里的dev.env.js和prod.env.js,添加sit.env.js文件,分别对应本地,正式和测试的配置文件。
这里需要强调一下,如果这几个文件修改了一定要重新npm run dev一下。
dev.env.js
'use strict' module.exports = { NODE_ENV: '"development"', ENV_CONFIG: '"dev"' }
prod.env.js
'use strict' module.exports = { NODE_ENV: '"production"', ENV_CONFIG: '"prod"' }
sit.env.js
'use strict' module.exports = { NODE_ENV: '"production"', ENV_CONFIG: '"sit"' }
修改build下的webpack.prod.conf.js文件找到const env = require('../config/prod.env')
修改成const env = require('../config/' + process.env.env_config + '.env')
vue默认是两个配置,一个是dev,一个prod,修改webpack.prod.conf.js后就可以判断是测试环境还是正式环境了。
// const env = require('../config/prod.env') const env = require('../config/' + process.env.env_config + '.env')
应用
在src文件夹里新建config文件夹,里面新建index.js
index.js
'use strict' // 根据环境引入不同配置 process.env.ENV_CONFIG ex:dev.conf.js const config = require('./' + process.env.ENV_CONFIG + '.conf') module.exports = config
dev.conf.js,sit.conf.js,prod.conf.js三个文件夹里写不同的配置。
// 配置本地测试 module.exports = { /* * action 七牛上传地址 * bucket 空间名 * domain 回显域名 */ qiniu: { action: 'https://up.qiniup.com', bucket: 'xxx', domain: 'xxx' }, // 接口地址配置 baseURL: 'https://localhost/api/v1' }
最后
直接使用就可以了。
import { qiniu } from '@/config/index.js'
console.log(qiniu.action)
原文地址:https://www.cnblogs.com/dianzan/p/15131974.html
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- Echarts图表宽度变成100px,让图表宽度随着父元素自动适应,Vue实时监听宽度的变化,这可能是史上最好的解决方案!
- Vim 基础和常用命令整理
- TinyMCE 优化百度地图 bdmap 插件
- 更新!万字长文带你拿下九大排序的原理、Java 实现以及算法分析
- mysql 同一张表查询 left join
- uni-app运行到浏览器跨域H5页面的跨域问题解决方案
- 手牵手,使用uni-app从零开发一款视频小程序 (系列上 准备工作篇)
- 树状数据库表查询2次以上(自连接、内连接、别名)方法
- 网页背景H5视频自动播放---PC端、移动端兼容问题完美解决方案(IOS、安卓、微信端)
- 【STM32F407】第11章 RL-TCPnet V7.X之TCP服务器
- 如何解决nodejs中cpu密集型的任务
- 博客园主题1【备份】
- 手牵手,使用uni-app从零开发一款视频小程序 (系列下 开发实战篇)
- POSTGRESQL 到底怎么访问同instance 的库--
- 简单工厂模式