Execution order of multiple setTimeout without delays in angular
up vote
1
down vote
favorite
What is the execution order of multiple setTimeout without delays in angular2+?
Example:
setTimeout(() => console.log('1'));
setTimeout(() => console.log('2'));
Questions:
(1) Is 1
always guaranteed to be printed before 2
?
(2) If so, what part of the spec says so?
(3) This is called in Angular2+ code. Is angular overriding setTimeout
's default behaviour?
How it differs from other questions:
This question (1) asks about the case without delay, and (2) asks it in angular context (in case angular overrides setTimeout
).
Non-questions:
I know console.log
might (or might not) be async or whatever; this question is not related to that. You can assume console.log
is sync.
javascript angular settimeout ngzone
add a comment |
up vote
1
down vote
favorite
What is the execution order of multiple setTimeout without delays in angular2+?
Example:
setTimeout(() => console.log('1'));
setTimeout(() => console.log('2'));
Questions:
(1) Is 1
always guaranteed to be printed before 2
?
(2) If so, what part of the spec says so?
(3) This is called in Angular2+ code. Is angular overriding setTimeout
's default behaviour?
How it differs from other questions:
This question (1) asks about the case without delay, and (2) asks it in angular context (in case angular overrides setTimeout
).
Non-questions:
I know console.log
might (or might not) be async or whatever; this question is not related to that. You can assume console.log
is sync.
javascript angular settimeout ngzone
add a comment |
up vote
1
down vote
favorite
up vote
1
down vote
favorite
What is the execution order of multiple setTimeout without delays in angular2+?
Example:
setTimeout(() => console.log('1'));
setTimeout(() => console.log('2'));
Questions:
(1) Is 1
always guaranteed to be printed before 2
?
(2) If so, what part of the spec says so?
(3) This is called in Angular2+ code. Is angular overriding setTimeout
's default behaviour?
How it differs from other questions:
This question (1) asks about the case without delay, and (2) asks it in angular context (in case angular overrides setTimeout
).
Non-questions:
I know console.log
might (or might not) be async or whatever; this question is not related to that. You can assume console.log
is sync.
javascript angular settimeout ngzone
What is the execution order of multiple setTimeout without delays in angular2+?
Example:
setTimeout(() => console.log('1'));
setTimeout(() => console.log('2'));
Questions:
(1) Is 1
always guaranteed to be printed before 2
?
(2) If so, what part of the spec says so?
(3) This is called in Angular2+ code. Is angular overriding setTimeout
's default behaviour?
How it differs from other questions:
This question (1) asks about the case without delay, and (2) asks it in angular context (in case angular overrides setTimeout
).
Non-questions:
I know console.log
might (or might not) be async or whatever; this question is not related to that. You can assume console.log
is sync.
javascript angular settimeout ngzone
javascript angular settimeout ngzone
asked Nov 11 at 0:57
Hossam El-Deen
112110
112110
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
up vote
1
down vote
accepted
1) Yes
2) Step 16 of https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html which says:
Wait until any invocations of this algorithm that had the same method
context, that started before this one, and whose timeout is equal to
or less than this one's, have completed.
3) No, Angular does not override it.
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).
– Hossam El-Deen
Nov 11 at 1:23
add a comment |
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
up vote
1
down vote
accepted
1) Yes
2) Step 16 of https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html which says:
Wait until any invocations of this algorithm that had the same method
context, that started before this one, and whose timeout is equal to
or less than this one's, have completed.
3) No, Angular does not override it.
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).
– Hossam El-Deen
Nov 11 at 1:23
add a comment |
up vote
1
down vote
accepted
1) Yes
2) Step 16 of https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html which says:
Wait until any invocations of this algorithm that had the same method
context, that started before this one, and whose timeout is equal to
or less than this one's, have completed.
3) No, Angular does not override it.
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).
– Hossam El-Deen
Nov 11 at 1:23
add a comment |
up vote
1
down vote
accepted
up vote
1
down vote
accepted
1) Yes
2) Step 16 of https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html which says:
Wait until any invocations of this algorithm that had the same method
context, that started before this one, and whose timeout is equal to
or less than this one's, have completed.
3) No, Angular does not override it.
1) Yes
2) Step 16 of https://html.spec.whatwg.org/multipage/timers-and-user-prompts.html which says:
Wait until any invocations of this algorithm that had the same method
context, that started before this one, and whose timeout is equal to
or less than this one's, have completed.
3) No, Angular does not override it.
answered Nov 11 at 1:03
user184994
10.8k11526
10.8k11526
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).
– Hossam El-Deen
Nov 11 at 1:23
add a comment |
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).
– Hossam El-Deen
Nov 11 at 1:23
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2
setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).– Hossam El-Deen
Nov 11 at 1:23
And for future readers wondering how the exotic step 16 is related: It's because, according to step 14, the rest of steps are parallel. So, actually the example in the original question is similar to the exotic example in step 16, in that the rest of the steps of the 2
setTimeout
calls are indeed running in parallel, but due to step 16, the first will finish first (i.e., executing step 18 & getting to the queue first).– Hossam El-Deen
Nov 11 at 1:23
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53244909%2fexecution-order-of-multiple-settimeout-without-delays-in-angular%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown