Асинхронный JavaScriptСтатические методы промисовeasy

Упрощенный Promise.all

Необходимо реализовать упрощенную версию стандартного метода Promise.all.

Допустим, у нас есть три промиса:

  • p1 резолвится значением "🍎" через 2 секунды
  • p2 резолвится значением "🍋" через 3 секунды
  • p3 резолвится значением "🍉" через 1 секунду

Функция all принимает массив промисов и возвращает новый промис. Через 3 секунды он резолвится масивом результатов переданных промисов. Порядок значений должен соответствовать порядку промисов в массиве.

Гарантируется, что входящие промисы никогда не станут rejected.

all([p1, p2, p3]).then(arr => { console.log(arr); // arr === ["🍎", "🍋", "🍉"] });

Полноценную версию нужно реализовать в задаче all.

Код для тестирования

const rand = () => Math.random() * 2000; const p1 = new Promise(r => setTimeout(r, rand(), "A")); const p2 = new Promise(r => setTimeout(r, rand(), "B")); const p3 = new Promise(r => setTimeout(r, rand(), "C")); const p4 = new Promise(r => setTimeout(r, rand(), "D")); all([p1, p2, p3, p4]).then( value => console.log("1 >>>", value), reason => console.log("2 >>>", reason), );