标签:instance 开发环境 也有 == roc fun default data promise
在vue项目中,和后台交互获取数据这块,我们通常使用的是axios库,它是基于promise的http库,可运行在浏览器端和node.js中。他有很多优秀的特性,例如拦截请求和响应、取消请求、转换json、客户端防御cSRF等。所以我们的尤大大也是果断放弃了对其官方库vue-resource的维护,直接推荐我们使用axios库。
npm install axios; // 安装axios
一般我会在项目的src目录中,新建一个request文件夹,然后在里面新建一个utils.js和一个api.js文件。http.js文件用来封装我们的axios,api.js用来统一管理我们的接口。
我们的项目环境可能有开发环境、测试环境和生产环境。我们通过node的环境变量来匹配我们的默认的接口url前缀。
// 环境的切换
if (process.env.NODE_ENV == ‘development‘) {
axios.defaults.baseURL = ‘https://www.baidu.com‘;}
else if (process.env.NODE_ENV == ‘debug‘) {
axios.defaults.baseURL = ‘https://www.ceshi.com‘;
}
else if (process.env.NODE_ENV == ‘production‘) {
axios.defaults.baseURL = ‘https://www.production.com‘;
}
通过axios.defaults.timeout设置默认的请求超时时间。例如超过了10s,就会告知用户当前请求超时,请刷新等。
axios.defaults.timeout = 10000;
post请求的时候,我们需要加上一个请求头,所以可以在这里进行一个默认的设置,即设置post的请求头为 application/x-www-form-urlencoded;charset=UTF-8
axios.defaults.headers.post[‘Content-Type‘] = ‘application/x-www-form-urlencoded;charset=UTF-8‘;
get方法:我们通过定义一个get函数,get函数有两个参数,第一个参数表示我们要请求的url地址,第二个参数是我们要携带的请求参数。get函数返回一个promise对象,当axios其请求成功时resolve服务器返回 值,请求失败时reject错误值。最后通过export抛出get函数。
/**
* get方法,对应get请求
* @param {String} url [请求的url地址]
* @param {Object} params [请求时携带的参数]
*/
export function get(url, params){
return new Promise((resolve, reject) =>{
axios.get(url, {
params: params
}).then(res => {
resolve(res.data);
}).catch(err =>{
reject(err.data)
})
});}
标签:instance 开发环境 也有 == roc fun default data promise
原文地址:https://www.cnblogs.com/oceanleader/p/12116171.html