这个问题在这里已有答案:
以下目前在节点,chrome,firefox中记录Yahtzee
。
正如你所看到的,甚至没有设定Promise的原型。
const fake = new Number(1)
fake.then = fn => setTimeout(fn, 0, 'Yahtzee')
const main = async () => {
console.log(await fake)
}
main()
这是否普遍适用?更重要的是,这种行为可能会持续存在吗?
是的,这会奏效。 According to the specs,一个新的Promise将被召唤并以此价值解决。 Promise.resolve
与thenable合作,所以它对await
也一样
所以,上面相当于
const fake = new Number(1)
fake.then = fn => setTimeout(fn, 0, 'Yahtzee')
const main = async () => {
console.log(await Promise.resolve(fake))
}
main()