如何解决承诺始终在Chrome控制台中处于待处理状态
为什么以下承诺永远无法解决?
const x= new Promise(resolve=>setTimeout(()=>resolve(12),5000));
通过在控制台中书写,
const x= new Promise(resolve=>resolve(12))
上午得到
`Promise {<fulfilled>: 12}`
通过写作
const x= new Promise(resolve=>setTimeout(()=>resolve(12),5000))
上午得到
Promise {<pending>}
认为,这应该在5秒后完成。但是,事实并非如此。为什么?
解决方法
控制台仅向您显示Promise的当前状态的快照。它不在监视状态的变化。
为什么以下承诺永远无法解决?
您可以清楚地看到5秒后此问题会解决:
const x= new Promise(resolve=>setTimeout(()=>resolve(12),5000)) ;
x.then(result => console.log(result));
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。