JavaScript的事件循环是其核心机制之一,它决定了JavaScript代码的执行顺序,事件循环的工作方式可以概括为:
(图片来源网络,侵删)1、首先执行同步代码,也就是我们的主线程代码。
2、然后等待队列中的任务(宏任务和微任务)。
3、当主线程空闲时,开始执行队列中的任务。
4、在每个任务执行完毕后,检查是否有新的任务加入队列,如果有则继续执行,如果没有则等待。
以下是一个简单的示例:
console.log('script start'); setTimeout(function() { console.log('setTimeout'); }, 0); Promise.resolve().then(function() { console.log('promise1'); }).then(function() { console.log('promise2'); }); console.log('script end');
在这个例子中,虽然setTimeout
的延迟时间设置为0,但是它仍然是一个异步任务,会被放入到任务队列中等待执行,而Promise的then方法注册的回调函数则会在当前脚本执行结束后立即执行,实际的输出顺序应该是:’script start’ > ‘script end’ > ‘promise1’ > ‘promise2’ > ‘setTimeout’。
最新评论
本站CDN与莫名CDN同款、亚太CDN、速度还不错,值得推荐。
感谢推荐我们公司产品、有什么活动会第一时间公布!
我在用这类站群服务器、还可以. 用很多年了。