老师,能不能详细讲解下对于传入一个有then方法的对象时的情况.

老师,能不能详细讲解下对于传入一个有then方法的对象时的情况.

<!DOCTYPE html>
<html lang="en">

<head>
<meta charset="UTF-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Document</title>
</head>

<body>
<script>
const obj = {
then(resolve, reject) {
console.log(123);
resolve(456)
},
}

const p = Promise.resolve(obj).then(data => {
console.log(data);
})
</script>
</body>

</html>

问题描述:

为什么调用obj的then方法就能使Promise.resolve(obj)返回的对象有状态?

能不能详细讲解下执行流程

正在回答

登陆购买课程后可参与讨论,去登陆

1回答

同学你好,可以参考以下思路来理解:

当定义好带有then方法的对象,并把该对象作为参数传入Promise.resolve()方法中时(代码如下),就会调用该对象的then()方法

Promise.resolve({
    then(a, b) {
        a(123);
    }
})

而then()方法定义时传入了两个形参a和b,调用时就会传入具体实参,此时Promise.resolve()就会将resolve, reject两个真实的方法作为具体实参传入then方法,从而对象中的then方法能够调用resolve()和reject()改变状态。

祝学习愉快!

  • __Promise 提问者 #1
    <!DOCTYPE html>
    <html lang="en">

    <head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    </head>

    <body>
    <script>
    Promise.resolve({
    then(resolve, reject) {
    console.log(123);
    resolve()
    }
    })

    new Promise(resolve => {
    resolve({
    then(resolve, reject) {
    console.log(456);
    resolve()
    }
    })
    })

    new Promise(resolve => {
    setTimeout(() => {
    console.log(789);
    resolve()
    }, 0)
    })

    console.log(0);
    </script>
    </script>
    </body>

    </html>

    老师,这三种都是这个例子的变形,效果是一样的对吗

    2021-07-04 15:03:38
  • 好帮手慕然然 回复 提问者 __Promise #2

    同学你好,这三种运行效果是一样的,最后Promise的状态都是成功状态。

    ​祝学习愉快!

    2021-07-04 15:56:41
问题已解决,确定采纳
还有疑问,暂不采纳

恭喜解决一个难题,获得1积分~

来为老师/同学的回答评分吧

0 星
请稍等 ...
意见反馈 帮助中心 APP下载
官方微信

在线咨询

领取优惠

免费试听

领取大纲

扫描二维码,添加
你的专属老师