通过promise封装ajax

简易的ajax封装

function ajax(url, method, callback) {
    let xhr = new XMLHttpRequest()                        // 生成一个新的XMLHttpRequest对象,具体参考https://developer.mozilla.org/zh-CN/docs/Web/API/XMLHttpRequest
    xhr.open(method, url)                                 // 初始化一个请求
    xhr.send()                                            // 发送请求
    xhr.onload = function () {                            // XMLHttpRequest请求成功完成时触发
      if (this.status === 200) {
        callback(JSON.parse(this.response))               // 回调方法
      } else {
        throw new Error("加载失败")
      }
    }
    xhr.onerror = function () {                            // 当 request 遭遇错误时触发。
      throw new Error("加载失败")
    }
  }

使用示例:

  let url = "https://api.apiopen.top/getJoke?page=1&count=2&type=video" // 这里有免费的开放接口https://blog.csdn.net/c__chao/article/details/78573737
  let method = "GET"

  ajax(url, method, value => {
    console.log(value)
  })

promise封装ajax

  function ajax(url, method) {
    return new Promise((resolve, reject) => {
      let xhr = new XMLHttpRequest()                        // 生成一个新的XMLHttpRequest对象,具体参考https://developer.mozilla.org/zh-CN/docs/Web/API/XMLHttpRequest
      xhr.open(method, url)                                 // 初始化一个请求
      xhr.send()                                            // 发送请求
      xhr.onload = function () {                            // XMLHttpRequest请求成功完成时触发
        if (this.status === 200) {
          resolve(JSON.parse(this.response))               // 回调方法
        } else {
          reject("加载失败")
        }
      }
      xhr.onerror = function () {                            // 当 request 遭遇错误时触发。
        reject("加载失败")
      }
    })
  }

使用示例:

  let url = "https://api.apiopen.top/getJoke?page=1&count=2&type=video" // 这里有免费的开放接口https://blog.csdn.net/c__chao/article/details/78573737
  let method = "GET"

  ajax(url, method).then(value => {
    console.log(value)
  }).catch(err => {
    console.log(err)
  })
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值