文章详情页
html5 - Javascript单线程中消息队列的执行疑问
浏览:117日期:2023-01-03 15:44:09
问题描述
陆陆续续看了一些js单线程,事件循环和消息队列的文章,但是有一个疑问是,当event loop消息队列的时候,假设里面有ajax和settimeout两个消息,当但是settimeout是先进入消息队列,ajax是后入,但是ajax先回馈结果了,settimout还没有,这个时候,event loop应该是先执行ajax吧?其实结合日常开发我也知道应该是这么回事,但是我看一些文章好像说异步消息队列也是按顺序轮询执行的,但是明明后面的比你先反馈,应该是先执行对把?
问题解答
回答1:ajax执行完,剩余事件进入 event loop. setTimeout 在延迟的时间结束时,将参数里的回掉放入event loop。
推荐你一个网站,在线掩饰event loophttp://latentflip.com/loupe
回答2:这个问题, 说起来比较长, 这里有篇文章, 很长但是建议深读. Ajax知识体系大梳理 | louis blog当然sf的专栏也是有的: Ajax知识体系大梳理 - 路易斯聊前端如果有不明白的地方, 直接文章底下给我留言就行.
回答3:按照我这两天看的情况,异步任务只有在完成相关触发条件才会被推入“任务队列”,等待主线程执行完同步任务按照先进先出的顺序执行“任务队列”中的任务。
标签:
JavaScript
相关文章:
1. javascript - 数组原声方法中的一段代码2. python小白的基础问题 关于while循环的嵌套3. MySQL客户端吃掉了SQL注解?4. javascript - JS设置Video视频对象的currentTime时出现了问题,IE,Edge,火狐,都可以设置,反而chrom却...5. 求大神帮我看看是哪里写错了 感谢细心解答6. javascript - 百度echarts series数据更新问题7. python - Django分页和查询参数的问题8. javascript - 图片能在网站显示,但控制台仍旧报错403 (Forbidden)9. php自学从哪里开始?10. phpstady在win10上运行
排行榜
