什么是地狱回调?解决回调地狱的两种方法

什么是地狱回调?解决回调地狱的两种方法:https://blog.csdn.net/Frazier1995/article/details/115513199

 

地狱回调概念:回调函数套回调函数的情况就叫做回调地狱,

//地狱回调
setTimeout(function () { //第一层
console.log('武林要以和为贵');
setTimeout(function () { //第二程
console.log('要讲武德');
setTimeout(function () { //第三层
console.log('不要搞窝里斗');
}, 1000)
}, 2000)
}, 3000)
promise解决方式
// promise解决方式
function fn(str) {
var p = new Promise(function (resolve, reject) {
//处理异步任务
var flag = true;
setTimeout(function () {
if (flag) {
resolve(str)
}
else {
reject('操作失败')
}
})
})
return p;
}

fn('武林要以和为贵')
.then((data) => {
console.log(data);
return fn('要讲武德');
})
.then((data) => {
console.log(data);
return fn('不要搞窝里斗')
})
.then((data) => {
console.log(data);
})
.catch((data) => {
console.log(data);
})
async/await解决方式

//封装一个返回promise的异步任务
function fn(str) {
var p = new Promise(function (resolve, reject) {
var flag = true;
setTimeout(function () {
if (flag) {
resolve(str)
} else {
reject('处理失败')
}
})
})
return p;
}

//封装一个执行上述异步任务的async函数
async function test() {
var res1 = await fn('武林要以和为贵'); //await直接拿到fn()返回的promise的数据,并且赋值给res
var res2 = await fn('要讲武德');
var res3 = await fn('不要搞窝里斗');
console.log(res1, res2, res3);
}
//执行函数
test()
————————————————
版权声明:本文为CSDN博主「仲夏你的梦」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/Frazier1995/article/details/115513199

 

 

posted on   byd张小伟  阅读(344)  评论(0编辑  收藏  举报

相关博文:
阅读排行:
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了
· 上周热点回顾(2.24-3.2)
历史上的今天:
2018-05-22 div中的div上下居中
2018-05-22 Vue路由详解
< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5

统计

点击右上角即可分享
微信分享提示