我们在写前端页面时可能需要对服务器返回的参数做多步处理,也就是第一个ajax请求到的参数,有可能会被另一个ajax请求当作参数传给后端。由于我们大多使用异步ajax请求,如果两个请求分开来写,就没法保证第一个ajax请求到的参数会及时传递给第二个ajax请求。
jquery中ajax的链式操作
当然在jquery中也可以采用嵌套的方法来解决上面问题。代码如下
$.ajax({
url: xxx,
success: function(resp){
$.ajax({
url: xxxx,
data: resp,
success: function(resp){
$.ajax({
//...
});
}
});
}
});
以上代码过于冗余且不直观。下面介绍前端promise方法,采用链式方式,解决这个问题。(现在大多数浏览器都已经内置支持了Promise)
首先我们将基于jquery的ajax请求封装成一个回调函数。
function newAjax(url, params, callback) {
const promise = new Promise(function (resolve,reject) {
$.ajax<