如何解决代码嵌套太深问题
$.ajax({ success: function () { $.ajax({ success: function () { $.ajax({ success: function () { complete(); } }); } }); } });
解决方案:
<script> /* * 拿几个setTimeout做例子。 * 一秒后输出1, 然后一秒后输出2, 然后一秒后输出3 * 原始做法是一句句嵌套下去 */ setTimeout(function(){ //输出1 console.log(1); setTimeout(function() { //输出2 console.log(2); setTimeout(function() { console.log(3); }, 1000); }, 1000); }, 1000); /* * 现在出现了一种比较好的写法, 就是用Promise.js来简单来写 */ var asny = function (text) { var promise = new Promise(function(resolve, reject) { setTimeout(function() { console.log(text); resolve(); }, 1000) }); return promise; } asny("1").then(function(){ return asny("2"); }).then(function () { return asny("3"); }).then(function() { console.log("done"); }); </script>
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步