解决回调地狱问题的两种方式

什么是回调地狱?

回调函数嵌套使用,外部回调函数异步执行的结果是嵌套的回调执行条件,就是俗称的套娃

  setTimeout(() => {
            console.log(1);
            setTimeout(() => {
                console.log(11);
                setTimeout(() => {
                    console.log(111);
                }, 1000)
            }, 1000)
        }, 1000)

注意:以下代码均以用户需求为打印用户数据 订单数据 商品数据的异步编程为例

解决方式1:生成器和迭代器

    // 解决回调地狱问题 异步编程打印 用户数据 订单数据 商品数据
        function userDate() {
            setTimeout(() => {
                let data = '用户数据'
                iterator.next(data)
            }, 1000)

        }

        function orderDate() {
            setTimeout(() => {
                let data = '订单数据'
                iterator.next(data)
            }, 1000)

        }

        function goodsDate() {
            setTimeout(() => {
                let data = '商品数据'
                iterator.next(data) //使用next执行函数并传入形参
            }, 1000)

        }

        function* gen() {
            // 使用yield形成断点,接收返回结果值并打印
            let user = yield userDate()
            console.log(user);
            let order = yield orderDate()
            console.log(order);
            let good = yield goodsDate()
            console.log(good);
        }
        let iterator = gen()
        iterator.next() //使用next执行函数

解决方式2:使用promise串联多个异步任务

  let p = new Promise((resolve, reject) => {
            setTimeout(() => {
                let data = '用户数据'
                resolve(data) //成功的返回结果,调用第一个成功的回调函数
            }, 1000)

        })
        // 每一个then方法的返回结果由他的指定函数的返回值决定
        p.then((value) => {
            // 第一个成功的回调函数返回一个新的promise对象
            console.log(value)
            return new Promise((resolve, reject) => {
                setTimeout(() => {
                    let data = '订单数据'
                    resolve(data)
                }, 1000)
            }).then(value => {
                console.log(value)
                return new Promise((resolve, reject) => {
                    setTimeout(() => {
                        let data = '商品数据'
                        resolve(data)
                    }, 1000)
                })
            }).then(
                value => {
                    console.log(value);
                }
            )
        }, (reason) => {
            console.log('输入错误');
        })

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值