欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue 组件的封装之基于axios的ajax请求方法

程序员文章站 2023-11-02 13:50:34
如下所示: 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请求方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。