那段代码是怎么回事
var start = new Date();
setTimeout(function() {
var end = new Date();
console.log('Time elapsed with func1:',end - start, 'ms');
}, 500);
setTimeout(function() {
var end = new Date();
console.log('Time elapsed with func2:',end - start, 'ms');
}, 250);
while (new Date() - start < 1000) {}日志:
Time elapsed with func2: 1001 ms
Time elapsed with func1: 1017 ms我希望func1首先被触发,因为它是第一个被添加到事件队列中的事件。然后,由于JS的单线程性质,请等到func1返回,然后在队列中执行下一个事件,即func2。
那么,发生了什么?
发布于 2016-01-09 08:49:57
不,等等。它不会将超时调用添加到事件队列中。它由webapi通过浏览器处理,然后当超时开始时,它会将您的函数添加到事件队列中。
这是什么:https://www.youtube.com/watch?v=8aGhZQkoFbQ#t=13m (从13点起)
https://stackoverflow.com/questions/34691428
复制相似问题