VUE 利用 webpack 给生产环境和发布环境配置不同的接口地址


声明:本文转载自https://my.oschina.net/u/3219445/blog/1585128,转载目的在于传递更多信息,仅供学习交流之用。如有侵权行为,请联系我,我会及时删除。

前言

我们在开发项目的时候,往往会在同一个局域网进行开发,前后端分离同时进行开发。我们前端调用后端给的接口也是在局域网内部的。但是,当项目推到线上的时候,我们会从真实服务器上获取接口,因此,我们可能在测试接口和真实接口之间频繁切换,让人十分恶心。

因此,我们有必要想办法解决这个问题。

本文是 Vue2+VueRouter2+webpack 构建项目实战 
的后续文章。理解本文内容,需要VUE相关技术基础。

第一步,分别设置不同的接口地址

首先,我们分别找到下面的文件:

/config/dev.env.js /config/prod.env.js

/config/dev.env.js

/config/prod.env.js

其实,这两个文件就是针对生产环境和发布环境设置不同参数的文件。我们打开dev.en.js文件。代码如下:

var merge = require('webpack-merge') var prodEnv = require('./prod.env')  module.exports = merge(prodEnv, {   NODE_ENV: '"development"' })

var merge = require('webpack-merge')

var prodEnv = require('./prod.env')

module.exports = merge(prodEnv, { NODE_ENV: '"development"' })

好,我们在NODE_ENV下面增加一项,代码如下:

var merge = require('webpack-merge') var prodEnv = require('./prod.env')  module.exports = merge(prodEnv, {   NODE_ENV: '"development"',   API_ROOT: '"//192.168.1.8/api"' })

var merge = require('webpack-merge')

var prodEnv = require('./prod.env')

module.exports = merge(prodEnv,

{ NODE_ENV: '"development"', API_ROOT: '"//192.168.1.8/api"' })

然后,我们编辑prod.env.js文件,

module.exports = {   NODE_ENV: '"production"',   API_ROOT: '"//www.baidu.com/api"' }

module.exports = { NODE_ENV: '"production"', API_ROOT: '"//www.baidu.com/api"' }

好。我们分别设定的路径已经有了。下面就是如何调用的问题了。

第二部,在代码中调用设置好的参数

以我们之前的演示代码为例。你自己的项目请根据你自己的情况调整。以下文件和代码仅供参考。

我们打开src/config/api.js文件,将原来开头的代码

// 配置API接口地址 var root = 'https://cnodejs.org/api/v1'

// 配置API接口地址

var root = 'https://cnodejs.org/api/v1'

修改为

// 配置API接口地址 var root = process.env.API_ROOT

// 配置API接口地址

var root = process.env.API_ROOT

然后就完成了我们的配置工作。最后,重启项目,就能使新配置的接口地址生效了。

在经过这样的配置之后,我们在运行

npm run dev
  •  

的时候,跑的就是测试接口。而我们运行

npm run build
  •  

打包项目的时候,打包的是服务器正式接口,我们就不用调来调去得了。

祝开心!

本文由 FungLeo 原创,允许转载,但必须保留首发链接。

2017年06月19日更新

上面的方法是没有问题的。但是需要重新运行 npm run dev 重新跑项目才能成功。

另外,为了解决跨域问题以及其他,我现在不推荐采用这种方式调用接口,而是采用webpack自带的代理功能来实现接口的调用。具体方法参见《webpack+vue-cil 配置接口地址代理以及将项目打包到子目录的方法

本文发表于2017年12月05日 16:33
(c)注:本文转载自https://my.oschina.net/u/3219445/blog/1585128,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。如有侵权行为,请联系我们,我们会及时删除.

阅读 1985 讨论 0 喜欢 0

抢先体验

扫码体验
趣味小程序
文字表情生成器

闪念胶囊

你要过得好哇,这样我才能恨你啊,你要是过得不好,我都不知道该恨你还是拥抱你啊。

直抵黄龙府,与诸君痛饮尔。

那时陪伴我的人啊,你们如今在何方。

不出意外的话,我们再也不会见了,祝你前程似锦。

这世界真好,吃野东西也要留出这条命来看看

快捷链接
网站地图
提交友链
Copyright © 2016 - 2021 Cion.
All Rights Reserved.
京ICP备2021004668号-1