Why Does A SetTimeout Delay Of 0 Still Run After All Other Synchronous Code In A For Loop?
Solution 1:
JavaScript, both in the browser and on the server, runs as an event loop. The runtime is constantly polling for events. Events consist of user actions (e.g. DOM element x was clicked), I/O (data came back from I/O or ajax call), and timer events (in this case). setTimeout(fn, 0)
simply adds an event to be processed by the event loop at minimum when 0 milliseconds have elapsed. It will always execute after the current event has been processed.
Solution 2:
Am I correct in saying the for-loop and any synchronous code is placed on the call stack before setTimeout
To be pedantic, setTimeout() itself gets called synchronously, and placed on the callstack right after console.log(i, 'started');
. It's the settimeout callback (in your case console.log(i)
) that gets queued and called asynchronously.
Post a Comment for "Why Does A SetTimeout Delay Of 0 Still Run After All Other Synchronous Code In A For Loop?"