zoukankan      html  css  js  c++  java
  • 用promise 封装 ajax(来自牛客)

    请使用Promise封装Ajax操作
    原始的Ajax操作如下:

    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    var onSuccess = function(result){}; //成功的回调
    var onFail = function(error){}; //失败的回调
    var req = new XMLHttpRequest();
    req.open("POST""www.baidu.com"true);
    req.onload = function(){
      if(req.readyState === 4 && req.status === 200){
        onSuccess(req.response);
      else {
        onFail(req.statusText);
      }
    }
    req.onerror = function(){
      onFail(Error("网络异常"));
    }
     
    解:------------------------------------------------------------------------------------------------------------------------------------------
    const ajax = url => {
        return new Promise((resolve, reject) => {
            let req = new XMLHttpRequest();
            req.open("POST", url, true);
            req.onload = () => {
              if(req.readyState === 4 && req.status === 200){
                resolve(req.response);
              else {
                reject(req.statusText);
              }
            }
            req.onerror = () => {
              reject(Error("网络异常"));
            }
        })
    }

     

  • 相关阅读:
    2020杭电多校第二场 1006.The Oculus
    2020杭电多校第一场 1005.Fibonacci Sum
    数论——中国剩余定理
    数论——线性同余方程
    数论——乘法逆元
    数论——裴蜀定理
    javascript预解析和作用域
    数组的排序..........加深难度
    值类型和引用类型
    js中的==和===
  • 原文地址:https://www.cnblogs.com/yanghai/p/14092233.html
Copyright © 2011-2022 走看看