-
Notifications
You must be signed in to change notification settings - Fork 8.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
ko: update
Promise.prototype.finally()
to original text (#17811)
* ko: fix error in `Promise.prototype.finally()` [Typo error in Promise.prototype.finally() page #14869](#14869) 이슈에서 제안했던 내용에 따라 수정했습니다. * ko: lint `Promise.prototype.finally()` page * ko: update `Promise.prototype.finally()` to original text #14965 을 위해 [원문](https://github.com/mdn/content/blob/main/files/en-us/web/javascript/reference/global_objects/promise/finally/index.md)에 맞춰 업데이트 했습니다. * ko: remove comment in `Promise.prototype.finally()` 번역하면서 남겨둔 주석을 지웠습니다. * ko: remove headers in `Promise.prototype.finally()` 린터봇의 코멘트 #17811 (comment) 에 따라 일부 헤더를 지웠습니다. * ko: change words to align with the glossary guide #17811 (comment) * ko: add l10n.sourceCommit #17811 (review) * ko: update 'Promise/finally' based on review #17811 (review)
- Loading branch information
1 parent
18401a7
commit 083ffeb
Showing
1 changed file
with
52 additions
and
30 deletions.
There are no files selected for viewing
82 changes: 52 additions & 30 deletions
82
files/ko/web/javascript/reference/global_objects/promise/finally/index.md
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -1,81 +1,103 @@ | ||
--- | ||
title: Promise.prototype.finally() | ||
slug: Web/JavaScript/Reference/Global_Objects/Promise/finally | ||
l10n: | ||
sourceCommit: 88d71e500938fa8ca969fe4fe3c80a5abe23d767 | ||
--- | ||
|
||
{{JSRef}} | ||
|
||
**`finally()`** 메소드는 {{jsxref("Promise")}} 객체를 반환합니다. Promise가 처리되면 충족되거나 거부되는지 여부에 관계없이 지정된 콜백 함수가 실행됩니다. 이것은 Promise가 성공적으로 수행 되었는지 거절되었는지에 관계없이 `Promise`가 처리 된 후에 코드가 무조건 한 번은 실행되는 것을 제공합니다. | ||
{{jsxref("Promise")}} 인스턴스의 **`finally()`** 메서드는 프로미스를 처리한 후(이행되거나 거부된 후) 호출할 함수를 예약합니다. | ||
이 메서드는 즉시 동등한 {{jsxref("Promise")}} 객체를 반환하므로 [프로미스 체이닝](/ko/docs/Web/JavaScript/Guide/Using_promises#chaining)이 가능합니다. | ||
|
||
이것은 Promise의 {{jsxref("Promise.then", "then()")}}과 {{jsxref("Promise.catch", "catch()")}} 핸들러에서의 코드 중복을 피하게 합니다. | ||
**`finally()`** 메서드를 사용하면 {{jsxref("Promise/then", "then()")}} 와 {{jsxref("Promise/catch", "catch()")}} 처리기 속 코드 중복을 피할 수 있습니다. | ||
|
||
## 문법 | ||
{{EmbedInteractiveExample("pages/js/promise-finally.html", "taller")}} | ||
|
||
```js | ||
p.finally(onFinally); | ||
## 문법 | ||
|
||
p.finally(function () { | ||
// settled (fulfilled or rejected) | ||
}); | ||
```js-nolint | ||
promiseInstance.finally(onFinally) | ||
``` | ||
|
||
### Parameters | ||
### 매개변수 | ||
|
||
- `onFinally` | ||
- : `Promise`가 처리된 후 {{jsxref("Function")}} 이 호출됩니다. | ||
- : 프로미스가 처리된 후 비동기적으로 실행될 함수입니다. 거부된 프로미스를 반환하지 않는 이상 반환 값은 무시됩니다. 함수는 인자 없이 호출됩니다. | ||
|
||
### Return value | ||
### 반환 값 | ||
|
||
`finally` 핸들러는 `onFinally` 라는 지정된 함수의 {{jsxref("Promise")}}가 반환됩니다. | ||
반환 값은 인스턴스와 동일한 {{jsxref("Promise")}} 입니다. 만약 처리기에서 예외가 발생하거나 거부된 프로미스를 반환하면, `finally()`가 반환한 프로미스는 대신 그 값으로 거부됩니다. 이외에는 처리기의 반환 값은 원래 프로미스의 상태에 영향을 주지 않습니다. | ||
|
||
## 설명 | ||
|
||
`finally()` 메서드는 결과에 관계없이 promise가 처리되면 무언가를 프로세싱 또는 정리를 수행하려는 경우에 유용합니다. | ||
`finally()` 메서드는 결과에 관계없이 프로미스가 처리되고 나서 무언가를 처리하거나 정리할 때 유용합니다. | ||
|
||
`finally()` 메서드는 `.then(onFinally, onFinally)` 를 호출하는 것과 매우 비슷하지만 몇 가지 차이점이 있습니다: | ||
`finally()` 메서드는 {{jsxref("Promise/then", "then(onFinally, onFinally)")}} 를 호출하는 것과 매우 비슷하지만 몇 가지 차이점이 있습니다. | ||
|
||
- 함수를 인라인으로 만들 때, 두 번 선언해야 하지 않고 한 번만 전달하거나 그것을 위한 변수를 만들 수 있습니다. | ||
- `finally` 콜백은 어떠한 인수도 전달받지 않습니다, 왜냐하면 promise가 이행되었는지 또는 거부되었는지를 판단할 수 없기 때문입니다. promise의 왜 거부되었는지 또는 이행되었을때 반환되는 값이 필요하지 않거나 제공할 필요가 없을 때 활용합니다. | ||
- Promise.reject (3) .finally (() => {}) Promise.reject (3) .finally (() => {}) (약속 안 함) )는 3으로 거부됩니다. | ||
- `Promise.resolve(2).then(() => {}, () => {})`(`undefined`로 해결될) 와 달리, `Promise.resolve(2).finally(() => {})` 는 값 `2`로 해결됩니다. | ||
- 유사하게 `Promise.reject(3).then(() => {}, () => {})` (`undefined`로 거부될)와는 달리 `Promise.reject(3).finally(() => {})` 는 값 `3`로 거부됩니다. | ||
- 함수를 인라인으로 만들 때, 두 번 선언하거나 변수에 할당할 필요 없이 한 번만 사용해서 전달할 수 있습니다. | ||
- `onFinally` 콜백은 인자를 받지 않습니다. 이행된 값 혹은 거부된 이유와 무관하게 처리하는 경우에만 실행되므로 인자가 필요하지 않습니다. | ||
- `finally()` 호출은 보통 외부의 영향을 받지 않으며 원래 프로미스의 최종 상태를 변경하지 않습니다. 다음 예시를 참고하세요. | ||
- `Promise.resolve(2).then(() => 77, () => {})` 는 `77`로 이행됩니다. 이와는 다르게, `Promise.resolve(2).finally(() => 77)` 는 `2`로 이행됩니다. | ||
- 유사하게 `Promise.reject(3).then(() => {}, () => 88)` 는 `88`로 거부됩니다. 이와는 달리 `Promise.reject(3).finally(() => {})` 는 `3`로 거부됩니다. | ||
|
||
> **참고:** `finally` 콜백에서 `throw` (또는 거부된 promise를 반환)하면 `throw()`를 호출 할 때 지정된 거부 이유로 새롭게 만들어진 promise를 반환합니다. | ||
> **참고:** `finally` 콜백 내 예외 발생 또는 거부된 프로미스를 반환하는 경우에는 거부된 프로미스를 반환합니다. 예를 들어 `Promise.reject(3).finally(() => { throw 99; })` 와 `Promise.reject(3).finally(() => Promise.reject(99))` 는 모두 `99`로 거부된 프로미스를 반환합니다. | ||
## 예제 | ||
{{jsxref("Promise/catch", "catch()")}}처럼 , `finally()`는 내부적으로 자신을 호출한 객체의 `then` 메소드를 호출합니다. `onFinally`가 함수가 아닌 경우, `then()`은 두 인자 모두 `onFinally`로 넘어가 호출되며, 즉 {{jsxref("Promise.prototype.then()")}}에게 유용한 처리기가 포함되지 않는다는 의미입니다. 그 외의 경우 then()은 내부적으로 생성된 두 개의 함수와 함께 호출되며, 다음과 비슷하게 동작합니다. | ||
|
||
> **경고:** 다음은 설명을 위한 예시이며 실제 폴리필이 아닙니다. | ||
```js | ||
promise.then( | ||
(value) => Promise.resolve(onFinally()).then(() => value), | ||
(reason) => | ||
Promise.resolve(onFinally()).then(() => { | ||
throw reason; | ||
}), | ||
); | ||
``` | ||
|
||
`finally()` 메서드가 `then()` 을 호출하기 때문에 서브클래싱을 지원합니다. 위 예시의 {{jsxref("Promise.resolve()")}} 호출을 주목하세요. 실제로 `onFinally()` 의 반환 값은 `Promise.resolve()` 와 동일한 방식으로 이행됩니다. 하지만 이행된 프로미스의 진짜 생성자는 서브클래스가 됩니다. `finally()` 는 이 생성자를 [`promise.constructor[@@species]`](/ko/docs/Web/JavaScript/Reference/Global_Objects/Promise/@@species) 에서 얻습니다. | ||
|
||
## 예시 | ||
|
||
### `finally()` 사용하기 | ||
|
||
```js | ||
let isLoading = true; | ||
|
||
fetch(myRequest) | ||
.then(function (response) { | ||
var contentType = response.headers.get("content-type"); | ||
.then((response) => { | ||
const 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 */ | ||
.then((json) => { | ||
/* JSON 처리 */ | ||
}) | ||
.catch(function (error) { | ||
console.log(error); | ||
.catch((error) => { | ||
console.error(error); // 이 줄도 오류가 발생할 수 있습니다. (예: console = {}) | ||
}) | ||
.finally(function () { | ||
.finally(() => { | ||
isLoading = false; | ||
}); | ||
``` | ||
|
||
## 명세 | ||
## 명세서 | ||
|
||
{{Specifications}} | ||
|
||
## 브라우저 호환성 | ||
|
||
{{Compat}} | ||
|
||
## 더보기 | ||
## 같이 보기 | ||
|
||
- [Polyfill of `Promise.prototype.finally` in `core-js`][] | ||
- {{jsxref("Promise")}} | ||
- {{jsxref("Promise.prototype.then()")}} | ||
- {{jsxref("Promise.prototype.catch()")}} | ||
|
||
[Polyfill of `Promise.prototype.finally` in `core-js`]: https://github.com/zloirock/core-js#ecmascript-promise |