promise封装jquery ajax,promise封装AJAX,既可用callback也可用.then(较新版的jquery也是如此)...

知识点

onreadystatechange和onload使用时的区别。

onreadystatechange是状态发生变化时触发,包括status,readyState都会触发

onload知识readyState===4就触发。也就是不管是否请求是否成功

//普通callback

//封装get

function doGet(url,callback,aynsc){

let xhr = new XMLHttpRequest();

xhr.open(url,"get",aynsc===true?true:false);

xhr.onreadystatechange=function(){

if(status===200&&readyState===4){

callback(xhr.responseText);

}

}

xhr.send(null);

}

//使用

doGet("https://segmentfault.com/write?freshman=1",function(){

console.log(data)

})

//promise封装

//封装get

function doGet(url,callback,aynsc){

return new Promise(function(resolved,rejected){

new XMLHttpRequest();

xhr.open(url,"get",aynsc===true?ture:false);

xhr.send(null);

xhr.οnlοad=function(){

resolved(xhr.responseText)

callback&&callback(xhr.responseText);

};

xhr.οnerrοr=function(err){

rejected(err)

callback&&callback(err);

}

})

}

//使用方式一

doGet("https://segmentfault.com/write?freshman=1",function(){

console.log(data)

})

//使用方式二

doGet("https://segmentfault.com/write?freshman=1").then(function(data){

console.log(data)

}).catch(fucntion(err){

console.log(err)

})

结论

是用promise

doGet("https://segmentfault.com/write?freshman=1")

.then(function(data){

console.log(data); //data第一个请求结果

return doGet("https://segmentfault.com/write?freshman=2");

}).then(function(data){

console.log(data) //data第二个请求结果,这里没办法拿到第一个请求结果,除非在外面用个变量接收

})

//不需要在外面引入变量接收(所有实例promise的peending都是fulfilled,all()的resolved才进入,只要有一个是rejected就会进入rejected)

let allPromise = Promise.all(doGet("https://segmentfault.com/write?freshman=1"),doGet("https://segmentfault.com/write?freshman=2"));

allPromise

.then(function(data){

console.log(data) //[第一个请求结果,第二个请求结果]

})

.catch(function(err){

console.log(err);

})

作者:Infogami

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值