关于Promise的一个问题,求大神们指教,已经是折磨两个小时了,问了朋友也说不清楚 #JavaScript#
全部评论
return 4其实就相当于返回了一个解决的Promise对象,按道理来说跟Promised.resolve(4)是一样的,为什么结果却是4在2的后面呢
点赞 回复
分享
发布于 2022-11-12 19:23 湖北
https://juejin.cn/post/6945319439772434469 姐妹,可以看看这个的评论
点赞 回复
分享
发布于 2022-11-12 19:53 北京
滴滴
校招火热招聘中
官网直投
return async里面的return才是包裹成promise
点赞 回复
分享
发布于 2022-11-12 20:08 江西
我能理解第2个图的答案,第1个图的答案是怎么出来的呀?
点赞 回复
分享
发布于 2022-11-12 20:11 陕西
再看这个https://www.zhihu.com/question/453677175/answer/1841325386,等我看懂了会写上自己的观点,欢迎大神们指点
点赞 回复
分享
发布于 2022-11-12 20:18 湖北
不一样的。简单来说,调用then方***返回一个新的Promise(new了一个),在new时候会传入一个executor回调函数(参数为resolve和reject函数),函数内部会判断传入then的onfulfilled回调函数返回值的类型,如果是Promise类型(例如图中的Promse.resolve()执行结果)会先调用它的then方法,并将新Promise的resovle作为参数传递使得下次then的时候获取到4,这时产生了新的微任务并被添加到任务队列中;如果是其他类型例如数字4,直接调用新Promise的resolve将其作为参数传递进去。所以传入then的函数返回的类型是否是Promise会影响执行结果。
点赞 回复
分享
发布于 2022-11-12 21:01 安徽
源码实在是难以理解,已经是裂开了,总的来说就是如果返回的是一个Promise对象的话,会消耗两个微任务,一个用来创建一个解决的Promise,另外一个就是用来同步这个Promise的状态,。期约就是有状态的对象,时刻保持状态的同步。上一个链如果返回了一个新期约,那么得告诉浏览器我返回了一个新期约,消耗一个微任务,然后浏览器要同步这个期约的状态,消耗一个微任务。同步完成后才能继续下面的链式调用。
点赞 回复
分享
发布于 2022-11-12 22:23 湖北
好复杂啊 看不懂 所以4为啥在那啊
点赞 回复
分享
发布于 2022-11-13 16:12 湖北

相关推荐

点赞 3 评论
分享
牛客网
牛客企业服务