博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue-cli生成的项目配置开发和生产环境不同的接口
阅读量:6988 次
发布时间:2019-06-27

本文共 1234 字,大约阅读时间需要 4 分钟。

vue-cli生成的项目,vue项目配置了不同开发环境的接口地址,axios.defaults.baseURL如何引用这个地址,这是在我发布项目的时候考虑的,于是想到了

方法一:

config下配置文件分别如下:

dev.env.js:'use strict'const merge = require('webpack-merge')const prodEnv = require('./prod.env')module.exports = merge(prodEnv, {  NODE_ENV: '"development"',  API_ROOT: '"//xxx.xxx.xxx.xxx:9001"'})prod.env.js'use strict'module.exports = {  NODE_ENV: '"production"',  API_ROOT: '"https://xxx.zzz.com"'}

我在app.vue和main.js中试了以下方法,可以生效,但是因为在配置API_ROOT的时候里面地址带双引号,所以不能直接使用该接口地址,如果去掉API_ROOT中的双引号,打包的时候又会报错。

const config = require('../config')import axios from 'axios';if (process.env.NODE_ENV === 'development') {  axios.defaults.baseURL = config.dev.env.API_ROOT;} else {  axios.defaults.baseURL = config.build.env.API_ROOT;}

所以暂时没想到该怎么解决这个问题…………遂放弃方法一。

 

方法二:(集热心网友提供的方案)

一般项目webpack会有两个或多个配置文件,如:

webpack.prod.conf.js  对应线上打包
webpack.dev.conf.js   对应开发环境

使用webpack.DefinePlugin就可以

开发环境(webpack.dev.conf.js)://开发环境下的baseURLnew webpack.DefinePlugin({  BASE_URL:"'xxxxxxxxx'"})线上环境(webpack.prod.conf.js): //线上环境下的baseURLnew webpack.DefinePlugin({  BASE_URL:"'xxxxxxxxx'"})

我们只需要在入口文件中写上:axios.defaults.baseURL = BASE_URL;即可。

 

通过配置了DefinePlugin,那么这里面的标识就相当于全局变量,你的业务代码可以直接使用配置的标识。

 

注意:这里配置

BASE_URL 属性值的时候要单独给里面的值再加一个引号,否则输出的值不是字符串,所以会报错。

转载地址:http://shwvl.baihongyu.com/

你可能感兴趣的文章
eclipse中Build Path-Add to Build Path对应到androidstud
查看>>
Mysql,Zookeeper,Redis,Mongodb压力测试结果
查看>>
JQuery中操作Css样式的方法
查看>>
企业级Android Application Activity管理
查看>>
自己动手写一个Alarm
查看>>
页面加载条实现思路
查看>>
WebSocket在HTTP Proxy下是可以,可是有点小笨拙之处给人造成不便
查看>>
10.新浪微博Swift项目第十天
查看>>
通过vsphere golang webservice sdk 获取vmware主机、虚拟机的监控数据【一】
查看>>
第二十八讲:tapestry与可重复使用的javaScript
查看>>
Spring Cloud Edgware新特性
查看>>
用docker 搭建 node.js服务,端口映射无效
查看>>
【转载】干货再次来袭!Linux小白最佳实践:《超容易的Linux系统管理入门书》(连载八)用命令实...
查看>>
VS2010 简单ATL COM开发
查看>>
Hadoop2.7.1配置NameNode+ResourceManager高可用原理分析
查看>>
linux重启oracle 各种方法
查看>>
mysql替换某个字段所有值
查看>>
mysql配置文件my.cnf详解
查看>>
jsp页面中的代码执行加载顺序
查看>>
java.lang.NoSuchFieldException: DEFAULT_PARAM
查看>>