vue 组件的封装之基于axios的ajax请求
2017-05-11 17:15
976 查看
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请求方法
- 在Vue-cli里基于axios封装复用请求
- 浅谈在Vue-cli里基于axios封装复用请求
- vue2.x Cnode社区是基于vue、vue-router、vuex、axios、es6开发
- vue2.x Cnode社区是基于vue、vue-router、vuex、axios、es6开发
- 详解vue中axios的封装
- 基于Vue的图片放大镜组件封装
- 基于vue、vue-router、axios的App项目的总结
- 初探 amaze-vue( 基于vue.js封装的Amaze UI 组件库)
- 基于Vue如何封装分页组件
- 基于cropper.js封装vue在线图片裁剪组件
- vue项目中对axios的封装
- 基于axios封装fetch方法及调用实例
- 初探 amaze-vue( 基于vue.js封装的Amaze UI 组件库)
- 基于axios封装fetch方法及调用
- 基于Vue封装分页组件
- vue中Axios的封装与API接口的管理详解
- vue中axios的封装问题(简易版拦截,get,post)
- 基于Vue封装分页组件
- ios开发——自定义的表情键盘(组件封装与自动布局)