js ajax回调 return,js异步回调解决方法

当一个接口需要依赖另一个接口的请求数据时

1.将请求数据的接口设为同步,之后调另一个接口

2.在请求数据接口的成功回调里调另一个接口。

但是当一个接口需要依赖很多个接口的请求数据  或者  一个依赖另一个,另一个再依赖另一个  的情况该怎么解决呢?

当然你可以按照单个接口依赖的方式层层嵌套,结果就是代码结构混乱,可读性差,性能差(一个需要依赖很多个的时候要把很多个设为同步)。

因此,我们需要一种更优雅的异步回调处理方式--Promise

直接上代码:

场景一:先调用getData1,再调用getData2,再调用getData3  ...

//创建一个Promise实例,获取数据。并把数据传递给处理函数resolve和reject。需要注意的是Promise在声明的时候就执行了。

var getData1=new Promise(function(resolve,reject){

$.ajax({

type:"get",

url:"index.aspx",

success:function(data){

if(data.Status=="1"){

resolve(data.ResultJson)//在异步操作成功时调用

}else{

reject(data.ErrMsg);//在异步操作失败时调用

}

}

});

})

var getData2= new Promise(function(resolve,reject){

$.ajax({

type:"get",

url:"index.aspx",

success:function(data){

if(data.Status=="1"){

resolve(data.ResultJson)//在异步操作成功时调用

}else{

reject(data.ErrMsg);//在异步操作失败时调用

}

}

});

})

var getData3=new Promise(function(resolve,reject){

$.ajax({

type:"get",

url:"index.aspx",

success:function(data){

if(data.Status=="1"){

resolve(data.ResultJson)//在异步操作成功时调用

}else{

reject(data.ErrMsg);//在异步操作失败时调用

}

}

});

})

getData1.then(function(res){

return getData2(res)

}).then(function(res){

return getData3(res)

}).then(function(res){

console.log(res)

}).cache(function(error){

console.log(error)

})

场景二:getData3的执行依赖getData1和getData2

//Promise的all方法,等数组中的所有promise对象都完成执行

Promise.all([getData1,getData2]).then(function([ResultJson1,ResultJson2]){

//这里写等这两个ajax都成功返回数据才执行的业务逻辑

getData3()

})

优点:这样的代码分工非常明确,ajax就是拿数据的,.then .catch方法就是处理业务逻辑,代码异常清晰。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值