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-...

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

查看所有标签

猜你喜欢:

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

编程之道

编程之道

杰弗雷﹒詹姆斯 / 清华大学出版社 / 1999-05 / 18.00元

本书出自美国一位善于进行哲学思考、有十多年工作经验的程序设计师——杰弗雷·詹姆斯之手,他以一种敏锐的眼光审视着发生在程序设计室里的各种各样的小故事,并利用古老的道家思想对其进行分析。简单的故事蕴含深奥的道理,是本书的最大特色。本书语言优美,比喻生动,可读性极强。一起来看看 《编程之道》 这本书的介绍吧!

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码

SHA 加密
SHA 加密

SHA 加密工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具