--- title: Promise.race() slug: Web/JavaScript/Reference/Global_Objects/Promise/race tags: - ECMAScript6 - Promise - Обещание - метод translation_of: Web/JavaScript/Reference/Global_Objects/Promise/race ---
Метод Promise.race(iterable) возвращает выполненное или отклоненное обещание, в зависимости от того, с каким результатом завершится первое из переданных обещаний, со значением или причиной отклонения этого обещания.
{{EmbedInteractiveExample("pages/js/promise-race.html")}}
Promise.race(iterable);
iterable
Выполненный или отклоненный {{jsxref("Promise")}} в зависимости от результата первого завершенного из переданных в итерируемом объекте обещаний.
Метод race
возвращает Обещание
(Promise
) с результатом, первого завершенного из переданных обещаний. Т.е. возвратит resolve или reject, в зависимости от того, что случится первым.
Promise.race
– пример с setTimeout
var p1 = new Promise(function(resolve, reject) { setTimeout(resolve, 500, "один"); }); var p2 = new Promise(function(resolve, reject) { setTimeout(resolve, 100, "два"); }); Promise.race([p1, p2]).then(function(value) { console.log(value); // "два" // Оба вернули resolve, однако p2 вернул результат первым }); var p3 = new Promise(function(resolve, reject) { setTimeout(resolve, 100, "три"); }); var p4 = new Promise(function(resolve, reject) { setTimeout(reject, 500, "четыре"); }); Promise.race([p3, p4]).then(function(value) { console.log(value); // "три" // p3 быстрее, поэтому выведется значение его resolve }, function(reason) { // Не вызывается }); var p5 = new Promise(function(resolve, reject) { setTimeout(resolve, 500, "пять"); }); var p6 = new Promise(function(resolve, reject) { setTimeout(reject, 100, "шесть"); }); Promise.race([p5, p6]).then(function(value) { // Не вызывается }, function(reason) { console.log(reason); // "шесть" // p6 быстрее, выводится его rejects });
Спецификация | Статус | Комментарий |
---|---|---|
{{SpecName('ES6', '#sec-promise.race', 'Promise.race')}} | {{Spec2('ES6')}} | Изначальное определение в стандарте ECMA. |
{{SpecName('ESDraft', '#sec-promise.race', 'Promise.race')}} | {{Spec2('ESDraft')}} |
The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request.
{{Compat("javascript.builtins.Promise.race")}}