回调地狱问题:
在使用JavaScript时,为了实现某些逻辑经常会写出层层嵌套的回调函数,如果嵌套过多,会极大影响代码可读性和逻辑,这种情况也被成为回调地狱。比如说你要把一个函数 A 作为回调函数,但是该函数又接受一个函数 B 作为参数,甚至 B 还接受 C 作为参数使用,就这样层层嵌套,人称之为回调地狱,代码阅读性非常差。
例如:要发送三个异步的请求要求前面一个请求完成之后再依次发送请求。
$.ajax{ url:'url1', success:result=>{ $.ajax{ url:'url2', success:result=>{ $.ajax{ url:'url3', success:result=>{ } }; } }; } };//这就是一个栗子
基于PROMISE解决
Promise:ES6新增的内置类,是为了管理异步操作的。
//封装成多个方法 let queryA = function(){ return new Promise(resolve=>{ $.ajax({ url:'url1', success:resolve, }); }); } let queryB = function(){ return new Promise(resolve=>{ $.ajax({ url:'url2', success:resolve, }); }); } let queryC = function(){ return new Promise(resolve=>{ $.ajax({ url:'url3', success:resolve, }); }); } //先将queryA返回的实例赋给promise,每次执行then都会返回新的Prmise实例 let promise = queryA(); promise.then(result=>{ console.log(1); return queryB();//将queryB的实例返回作为下一个的实例用于调用下一个then }).then(result=>{ console.log(2); return queryC(); }).then(result=>{ console.log(3); });