vue 组件的封装之基于axios的ajax请求方法
程序员文章站
2022-06-11 18:18:39
如下所示:
import vue from 'vue'
let service = {
url: 'http://host.xxxxx.com/xxx...
如下所示:
import vue from 'vue' let service = { url: 'http://host.xxxxx.com/xxx.php' } service.ajaxreuqest = (url, options, type, fileflag) => { for (const i in options) { if (!options[i] && options[i] !== 0 && (options[i].length && options[i].length > 0)) { delete options[i] } } let promise = new promise((resolve, reject) => { if (fileflag) { vue.axios.post(url, options, { headers: { 'content-type': 'multipart/form-data' } }).then((res) => { resolve(res) }) } else if (type === 'get') { vue.axios.get(url, { params: options }).then((res) => { resolve(res.data.resultobj) }).then((err) => { reject(err) }) } else { vue.axios.post(url, options).then((res) => { resolve(res) }).then((err) => { reject(err) }) } }) return promise }
支持post get请求以及图片上传,基于axios,适用于vue,
以异步获取省份列表作为例子:
// 获取省份信息 service.getprovincelist = (options) => { return service.ajaxrequest(service.url + '/basic/getprovincelist', options, 'post') }
getprovincelist () { service.getprovincelist({}).then((res) => { this.provincelist = res.data.resultobj.data }) }
以上这篇vue 组件的封装之基于axios的ajax请求方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
推荐阅读