iview-admin多环境配置打包

栏目: 编程工具 · 发布时间: 6年前

内容简介:由于目前我在公司已经搭建了PS:

前言

由于目前我在公司已经搭建了 Jenkins 来进行一键系统发布,同时存在测试和生产两套环境。但是目前 iview-admin 是不支持的,只好自己进行改造了。

PS: iview-admin 版本为 2.1.0

改造方案

iview-admin 2.1.0 比起 iview-admin 2.1.0 ,移除了 config 目录且将 vue-cli 升级到 3.0

所以可以使用 vue-cli 3.0 的环境变量和模式特性来支持多环境配置打包。

在根目录添加环境变量文件

  1. 新增开发环境文件 .env.dev ,内容如下:
NODE_ENV = 'dev'
MOCK = true
BASE_URL= '/'
  1. 新增测试环境文件 .env.test ,内容如下:
NODE_ENV = 'test'
MOCK = false
BASE_URL= '/test'
  1. 新增生产环境文件 .env.prod ,内容如下:
NODE_ENV = 'prod'
MOCK = false
BASE_URL= '/prod'

环境变量文件中各个属性的用途如下:

  1. NODE_ENV 为对应的环境
  2. MOCK 为是否引入 mock.js 文件的标识
  3. BASE_URL 为前端项目访问时的相对地址

修改package.json

修改 scriptsdevbuild ,修改后内容如下:

"scripts": {
        "dev": "vue-cli-service serve --open --mode dev",
        "build:test": "vue-cli-service build --mode test",
        "build:prod": "vue-cli-service build --mode prod",
        "lint": "vue-cli-service lint",
        "test:unit": "vue-cli-service test:unit",
        "test:e2e": "vue-cli-service test:e2e"
    },

修改后的指令

npm run dev
npm run build:test
npm run build:prod

修改vue.config.js文件

修改 BASE_URL (此参数控制的是前端项目访问时的相对地址),改为从环境变量中获取,内容如下:

const BASE_URL = process.env.BASE_URL

修改src/config/index.js文件

修改 baseUrl ,改为多个后端API接口的配置,内容如下:

baseUrl: {
    dev: 'http://localhost:8081',
    test: 'http://www.test.com',
    prod: 'http://www.prod.com'
  },

修改src/libs/api.request.js文件

修改 baseUrl (对应后端API接口的地址),改为根据环境变量获取对应的 URL ,内容如下:

const baseUrl = config.baseUrl[process.env.NODE_ENV]

修改src/main.js文件

修改 mock 包引入判断,改为从环境变量中获取,内容如下:

if (process.env.MOCK) require('@/mock')

参考资料

  1. https://cli.vuejs.org/zh/guid...
  2. https://github.com/vuejs/vue-...

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

马云内部讲话

马云内部讲话

阿里巴巴集团 / 红旗出版社 / 2010-12 / 28.00元

马云的话有什么其妙的地方? 为什么员工会把自己的CEO当作偶像? 世界都处在迷茫期,他如何确立阿里巴巴的价值观? 他怎样给已经是富翁的员工寻找新的激情? 风暴袭来,他怎么克服内心的恐惧? 他在互联网合纵连横的动机何在?一起来看看 《马云内部讲话》 这本书的介绍吧!

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

随机密码生成器
随机密码生成器

多种字符组合密码

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码