【vue ajax】封装ajax,可直接复用

在项目经过统一代理后,部分功能想直接发送请求,不用统一api,可以封装一个ajax进行网络传输

    ajax(method, url, data) {
      return new Promise(function (resolve, reject) {
        const xhr = new XMLHttpRequest();
        xhr.onreadystatechange = function () {
          if (xhr.readyState == 4) {
            if (xhr.status == 200) {
              resolve(JSON.parse(xhr.response))
            } else {
              reject({
                code: xhr.status
              })
            }
          }
        }
        method = method.toLowerCase()
        //如果是get请求,将参数拼接到url中
        if (method == 'get') {
          const arr = []
          for (let key in data) {
            arr.push(
              key + '=' + encodeURIComponent(data[key])
            )
          }
          arr.join('&')
          url += '?' + arr.join('&')
        }


        xhr.open(method, url, true);

        xhr.setRequestHeader('Authorization', 'Bearer ' + localStorage.getItem('token'))
        //如果是post请求
        if (method == 'post') {
          xhr.setRequestHeader('Content-Type', 'application/x-www-form-urlencoded');
          xhr.send(JSON.stringify(data))
        } else {
          xhr.send();
        }
      })
    },

可以把上面函数直接放在method就可直接调用了

其中要注意post的请求头的参数要符合接口要求

如果参数是直接拼到url后面,那也可以拼接好,直接传url,data不用传就行

相关推荐

  1. Promise封装ajax

    2024-01-26 11:56:03       15 阅读
  2. 12.使用Promise封装Ajax

    2024-01-26 11:56:03       35 阅读
  3. 手搓ajax封装

    2024-01-26 11:56:03       16 阅读
  4. Axios(对AJAX封装和简化)

    2024-01-26 11:56:03       13 阅读
  5. js请求封装ajax、统一响应

    2024-01-26 11:56:03       12 阅读
  6. react 封装请求axios,直接调用即可

    2024-01-26 11:56:03       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2024-01-26 11:56:03       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-01-26 11:56:03       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-01-26 11:56:03       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-01-26 11:56:03       18 阅读

热门阅读

  1. 04 约数

    04 约数

    2024-01-26 11:56:03      32 阅读
  2. kotlin sum 与 sumOf

    2024-01-26 11:56:03       35 阅读
  3. Android.bp 语

    2024-01-26 11:56:03       36 阅读
  4. kotlin中的初始化问题纪录

    2024-01-26 11:56:03       31 阅读
  5. 大厂程序员成长路径

    2024-01-26 11:56:03       38 阅读
  6. 深度挖掘:前端架构设计与现代化实践

    2024-01-26 11:56:03       34 阅读
  7. golang视角下 protobuf 的安装 从proto文件到go文件

    2024-01-26 11:56:03       31 阅读