Es6- 使用promise的方法封装自己的ajax

promise封装自己的ajax:

  const getJSON = function(url){

    return new promise((resolved,rejected)=>{

      const xhrs = new XMLHttpRequest();

      xhrs.open('GET',url);

      xhrs.onreadystatechange = handler;

      xhrs.responseType = 'json';

      xhrs.setRequestHeader('Accept','application/json');

      xhrs.send();//get请求数据是放在url中,如果是post,此处需要添加对应的数据

      function handler(){

        if(this.readyState ===4){

          if(this.status ===200){      

            resolved(this.response) //返回的根据自己的情况进行展示

          }else{

            rejected(this,error)//返回的根据自己的情况进行展示

          }

        }

      }

    })

  }

  getJSON('XXXXXXXXXXXXXXXXXX').then((res)=>{

    console.log(res)

  },(error)=>{

     console.log(error);

  })

还有一种写法是

  getJSON('XXXXXXXXXXXXXXXXXX').then((res)=>{

    console.log(res)

  }).catch(err =>{

    console.log(err);

  })

  

posted @ 2022-05-06 17:07  一封未寄出的信  阅读(91)  评论(0编辑  收藏  举报