.then(() => console.log(2))
.then(() => console.log(3))
.then(() => console.log(4))
я правильно понимаю, что для выполнения следующего промиса, необходимо что бы предыдущий выполнился и удалился из очереди микрозадач?
Они все лежат в очереди микрозадач. Потому что код выше создал пять промисов. Просто их выполнение зависит друг от друга. Если я не прав - подскажите.
Так а про очередной итерации ивент лупа разве очередь он очищается?
Да
Наврал я тебе немножко. Вся эта очередь выполнится в рамках одного этапа эвент лупа. Что-то вроде бесконечной итерации сверху вниз по пачке промисов, пока не останутся только те что pending. Promise.resolve() .then(() => console.log('a 1')) .then(() => console.log('a 2')) .then(() => console.log('a 3')) .then(() => console.log('a 4')) Promise.resolve() .then(() => console.log('b 1')) .then(() => new Promise(resolve => { console.log('b 2') resolve() })) .then(() => console.log('b 3')) .then(() => console.log('b 4')) setTimeout(() => console.log('macro')) // a 1 // b 1 // a 2 // b 2 // a 3 // a 4 // b 3 // b 4 // macro
Ага... Каждый then пихает свою микрозадачу в очередь, тем самым запрещая новую итерацию лупа, и так до тех пор пока очередь не очистится, т.е. поко вся цепочка не выполнится. Нашел достаточно наглядный эмулятор этих вещей, очень крутая штука: https://www.jsv9000.app/ P.S. за ответ огромная благодарность
Добавил в закладки.
а на том сайте как можно сделать твой пример, без анонимных функций, я что то не очень понимаю как он в тасски что кидает
Обсуждают сегодня