Перевод не завершен. Пожалуйста, помогите перевести эту статью с английского.

Метод finally() возвращает Promise. Когда Promise (обещание) был выполнен, в не зависимости успешно или с ошибкой, указаная функция будет выполнена. Это дает возможность запустить один раз определенный участок кода, который должен выполнится вне зависимости от того, с каким результатом выполнился Promise.

Это позволяет вам избавиться от дубликации кода в обработчиках then() и catch().



p.finally(function() {
   // завершен (успешно или с ошибкой)


Функция Function вызываемая когда Promise (обещание) завершено.

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

Returns a Promise whose finally handler is set to the specified function, onFinally.


The finally() method can be useful if you want to do some processing or cleanup once the promise is settled, regardless of its outcome.

The finally() method is very similar to calling .then(onFinally, onFinally) however there are couple of differences:

  • When creating a function inline, you can pass it once, instead of being forced to either declare it twice, or create a variable for it
  • A finally callback will not receive any argument, since there's no reliable means of determining if the promise was fulfilled or rejected. This use case is for precisely when you do not care about the rejection reason, or the fulfillment value, and so there's no need to provide it.
  • Unlike Promise.resolve(2).then(() => {}, () => {}) (which will be resolved with undefined), Promise.resolve(2).finally(() => {}) will be resolved with 2.
  • Similarly, unlike Promise.reject(3).then(() => {}, () => {}) (which will be resolved with undefined), Promise.reject(3).finally(() => {}) will be rejected with 3.

Note: A throw (or returning a rejected promise) in the finally callback will reject the new promise with the rejection reason specified when calling throw().


let isLoading = true;

fetch(myRequest).then(function(response) {
    var contentType = response.headers.get("content-type");
    if(contentType && contentType.includes("application/json")) {
      return response.json();
    throw new TypeError("Oops, we haven't got JSON!");
  .then(function(json) { /* process your JSON further */ })
  .catch(function(error) { console.log(error); })
  .finally(function() { isLoading = false; });


Specification Status Comment
TC39 proposal Stage 4  

Browser compatibility

Update compatibility data on GitHub
ChromeEdgeFirefoxInternet ExplorerOperaSafariAndroid webviewChrome для AndroidEdge MobileFirefox для AndroidOpera для AndroidiOS SafariSamsung InternetNode.js
Базовая поддержкаChrome Полная поддержка 63Edge Нет поддержки НетFirefox Полная поддержка 58IE Нет поддержки НетOpera Полная поддержка 50Safari Полная поддержка 11.1WebView Android Полная поддержка 63Chrome Android Полная поддержка 63Edge Mobile Нет поддержки НетFirefox Android Полная поддержка 58Opera Android Полная поддержка 50Safari iOS Полная поддержка 11.1Samsung Internet Android Нет поддержки Нетnodejs Полная поддержка 10.0.0


Полная поддержка  
Полная поддержка
Нет поддержки  
Нет поддержки

See also

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

Внесли вклад в эту страницу: Zudwa, x1unix
Обновлялась последний раз: Zudwa,