vue-cli生成的项目配置开发和生产环境不同的接口
2018-06-24 00:37:54来源:未知 阅读 ()
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): //开发环境下的baseURL new webpack.DefinePlugin({ BASE_URL:"'xxxxxxxxx'" }) 线上环境(webpack.prod.conf.js): //线上环境下的baseURL new webpack.DefinePlugin({ BASE_URL:"'xxxxxxxxx'" })
我们只需要在入口文件中写上:axios.defaults.baseURL = BASE_URL;
即可。
通过配置了DefinePlugin,那么这里面的标识就相当于全局变量,你的业务代码可以直接使用配置的标识。
注意:这里配置
BASE_URL
属性值的时候要单独给里面的值再加一个引号,否则输出的值不是字符串,所以会报错。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
上一篇:你所不知道的全景图
下一篇:JS中那些让人头昏眼花的弯子
- nodejs的express自动生成项目框架的方法 2020-02-20
- vue-cli中打包图片路径错误的解决方法 2020-01-17
- Javascript的&&和||的另类用法 2020-01-07
- JS简单随机数生成方法 2019-12-29
- js判断文本框剩余可输入字数的方法 2019-12-13
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash