vue中请求接口怎么封装公共地址_vue中请求接口怎么封装公共地址_vue系列-封装http请求...

功能

支持RESful风格(get,post,delete,put,patch)

支持处理格式化URL(/demo/{id})

支持请求错误码跳转到指定url

使用

对外提供两个方法

http(url = '', data = {}, method = "GET"):使用http请求

getUrl(url = ''):构建完整的url

代码

import axios from 'axios';

//创建axios实例

const service = axios.create({

timeout: 30000 //超时时间

})

//添加request拦截器

service.interceptors.request.use(config => {

return config;

}, error => {

Promise.reject(error);

})

//添加response拦截器

service.interceptors.response.use(

response => {

let res = {};

res.status = response.status;

res.data = response.data;

return res;

},

error => {

if (error.response && error.response.status == 404) {

//跳转到xx页面

console.log("404错误")

}

return Promise.reject(error.response)

}

)

//封装get接口

// params={} 是设置默认值

export function get(url, params = {}) {

params.t = new Date().getTime(); //get方法加一个时间参数,解决ie下可能缓存问题.

return service({

url: url,

method: 'get',

headers: {

},

params

})

}

//封装post请求

export function post(url, data = {}) {

//默认配置

let sendObject = {

url: url,

method: "post",

headers: {

'Content-Type': 'application/json;charset=UTF-8'

},

data: data

};

sendObject.data = JSON.stringify(data);

return service(sendObject)

}

//封装put方法 (resfulAPI常用)

function put(url, data = {}) {

return service({

url: url,

method: 'put',

headers: {

'Content-Type': 'application/json;charset=UTF-8'

},

data: JSON.stringify(data)

})

}

//删除方法(resfulAPI常用)

function deletes(url) {

return service({

url: url,

method: 'delete',

headers: {}

})

}

//patch方法(resfulAPI常用)

function patch(url) {

return service({

url: url,

method: 'patch',

headers: {}

})

}

//处理格式化URL(/demo/{id})

function render(url, data) {

var re = /{([^]+)?}/

var match = ''

while ((match = re.exec(url))) {

url = url.replace(match[0], data[match[1]])

}

return url

}

const fetch = (options) => {

//process.env.VUE_APP_PATH为环境变量在.env文件中配置

let url = process.env.VUE_APP_PATH + options.url;

url = render(url, options.data)

switch (options.method.toUpperCase()) {

case 'GET':

return get(url, options.data)

case 'POST':

return post(url, options.data)

case 'PUT':

return put(url, options.data)

case 'DELETE':

return deletes(url, options.data)

case 'PATCH':

return patch(url, options.data)

default:

return service(options)

}

}

/**

* 提供一个http方法

* url 访问路径 不包括域名和项目名

* data 参数对象

* method 请求方式

* */

export function http(url = '', data = {}, method = "GET") {

const options = { url: url, data: data, method: method }

return fetch(options).catch(error => {

console.log(error)

throw error

})

}

/**

* 构造url的方法

*/

export function getUrl(url = '') {

//process.env.VUE_APP_PATH为环境变量在.env文件中配置

return process.env.VUE_APP_PATH + url;

}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值