Please note, this is a STATIC archive of website developer.mozilla.org from November 2016, cach3.com does not collect or store any user information, there is no "phishing" involved.

Promise.all()

Эта статья нуждается в редакционном обзоре. Как вы можете помочь.

Общее описание

Метод Promise.all(iterable) возвращает обещание, которое выполнится тогда, когда будут выполнены все обещания, переданные в виде перечисляемого аргумента, или отклонено любое из переданных обещаний.

Синтаксис

Promise.all(iterable);

Параметры

iterable
Перечисляемый объект, например, массив (Array). Смотрите iterable.

Возвращаемое значение

Promise который будет выполнен когда будут выполнены все обещания, переданные в виде перечисляемого аргумента, или отклонен, если будет отклонено хоть одно из переданных обещаний.

Описание

Promise.all передает массив значений от всех обещаний, которые были ему переданы. Возвращаемый массив значений сохраняет порядок оригинального перечисляемого объекта, но не порядок выполнения обещаний. Если какой-либо элемент перечисляемого объекта не является обещанием, то он будет преобразован с помощью метода Promise.resolve.

Если одно из переданных обещаний будет отклонено, Promise.all будет немедлено отклонен со значениям отклоненного обещания, не учитывая другие обещания, независимо выполнены они или нет. Если в качестве аргумента будет передан пустой массив, то Promise.all будет выполнен немедленно. 

Примеры

Использование Promise.all

Promise.all ждет выполнения всех обещаний (или первого метода reject())

var p1 = Promise.resolve(3);
var p2 = 1337;
var p3 = new Promise((resolve, reject) => {
  setTimeout(resolve, 100, "foo");
}); 

Promise.all([p1, p2, p3]).then(values => { 
  console.log(values); 
});

//Выведет: 
// [3, 1337, "foo"] 

Promise.all поведение немедленного отклонения

Promise.all будет немедленно отклонен если одно из переданных обещаний будет отклонено: если у вас есть четыре обещания которые будут выполнены с задержкой и одно, которое будет отклонено немедленно - тогда Promise.all будет немедленно отклонен.

var p1 = new Promise((resolve, reject) => { 
  setTimeout(resolve, 1000, "one"); 
}); 
var p2 = new Promise((resolve, reject) => { 
  setTimeout(resolve, 2000, "two"); 
});
var p3 = new Promise((resolve, reject) => {
  setTimeout(resolve, 3000, "three");
});
var p4 = new Promise((resolve, reject) => {
  setTimeout(resolve, 4000, "four");
});
var p5 = new Promise((resolve, reject) => {
// Это обещание прервет Promise.all
  reject("reject");
});

Promise.all([p1, p2, p3, p4, p5]).then(value => { 
  console.log(value);
}, reason => {
  console.log(reason)
});

//Выведет:
//"reject"

Спецификации

Спецификация Статус Пояснение
ECMAScript 2017 Draft (ECMA-262)
Определение 'Promise.all' в этой спецификации.
Черновик  
ECMAScript 2015 (6th Edition, ECMA-262)
Определение 'Promise.all' в этой спецификации.
Стандарт Первоначальный вариант в стандарте ECMA.

Совместимость с браузерами

Свойство Chrome Firefox (Gecko) Internet Explorer Opera Safari Servo
Базовая поддержка 32 29.0 (29.0) Нет 19 7.1 Нет
Свойство Android Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile Chrome for Android Edge Mobile
Базовая поддержка 4.4.4 29.0 (29.0) Нет (Yes) iOS 8 32 (Yes)

Родственные темы

Метки документа и участники

 Внесли вклад в эту страницу: rutsky, NikIvan, AlexKhram, Crazymax11, f0rmat1k, axilirator
 Обновлялась последний раз: rutsky,