aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--files/ko/web/javascript/reference/global_objects/intl/datetimeformat/datetimeformat/index.md273
-rw-r--r--files/ko/web/javascript/reference/global_objects/intl/datetimeformat/index.md301
2 files changed, 348 insertions, 226 deletions
diff --git a/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/datetimeformat/index.md b/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/datetimeformat/index.md
new file mode 100644
index 0000000000..a27f5aa944
--- /dev/null
+++ b/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/datetimeformat/index.md
@@ -0,0 +1,273 @@
+---
+title: Intl.DateTimeFormat() 생성자
+slug: Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat
+tags:
+ - Constructor
+ - DateTimeFormat
+ - Internationalization
+ - Intl
+ - JavaScript
+ - Localization
+ - Reference
+browser-compat: javascript.builtins.Intl.DateTimeFormat.DateTimeFormat
+translation_of: Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat/DateTimeFormat
+---
+{{JSRef}}
+
+**`Intl.DateTimeFormat`** 생성자는 언어에 맞는 날짜 및 시간 서식을 적용하기 위한 {{jsxref("Intl/DateTimeFormat", "Intl.DateTimeFormat")}} 객체를 생성합니다.
+
+{{EmbedInteractiveExample("pages/js/intl-datetimeformat.html", "taller")}}
+
+## 구문
+
+```js
+new Intl.DateTimeFormat()
+new Intl.DateTimeFormat(locales)
+new Intl.DateTimeFormat(locales, options)
+```
+
+### 매개변수
+
+- `locales` {{optional_inline}}
+
+ - : [BCP 47](https://ko.wikipedia.org/wiki/IETF_%EC%96%B8%EC%96%B4_%ED%83%9C%EA%B7%B8) 언어 태그를 포함하는 문자열이나 문자열의 배열입니다. 브라우저 기본 로케일을 사용하려면 빈 배열을 지정하세요. `en-US-u-ca-buddhist`처럼 유니코드 확장 형태도 지원합니다. 로케일 매개변수의 일반적인 형식 및 해석은 {{jsxref("Intl", "Intl", "#Locale_identification_and_negotiation", 1)}} 문서를 참고하세요. 다음의 유니코드 확장 키를 사용할 수 있습니다.
+
+ - `nu`
+ - : 사용할 기수법. "`arab`",
+ "`arabext`", "`bali`", "`beng`",
+ "`deva`", "`fullwide`", "`gujr`",
+ "`guru`", "`hanidec`", "`khmr`",
+ "`knda`", "`laoo`", "`latn`",
+ "`limb`", "`mlym`", "`mong`",
+ "`mymr`", "`orya`", "`tamldec`",
+ "`telu`", "`thai`", "`tibt`" 등을 사용할 수 있습니다.
+ - `ca`
+ - : 역법. "`buddhist`",
+ "`chinese`", "`coptic`", "`ethiopia`",
+ "`ethiopic`", "`gregory`", "`hebrew`",
+ "`indian`", "`islamic`", "`iso8601`",
+ "`japanese`", "`persian`", "`roc`" 등을 사용할 수 있습니다.
+ - `hc`
+ - : 시간제. "`h11`",
+ "`h12`", "`h23`", "`h24`" 등을 사용할 수 있습니다.
+
+- `options` {{optional_inline}}
+
+ - : 다음 속성 일부 또는 전부를 포함하는 객체입니다.
+
+ - `dateStyle`
+ - : `format()`을 호출했을 때 사용할 날짜 서식입니다. 가능한 값은 다음을 포함합니다.
+ - "`full`"
+ - "`long`"
+ - "`medium`"
+ - "`short`"
+
+ > **참고:** `dateStyle`은 `timeStyle`과 함께 사용할 수 있지만, 다른 옵션인 `weekday`, `hour`, `month` 등과는 함께 사용할 수 없습니다.
+
+ - `timeStyle`
+ - : `format()`을 호출했을 때 사용할 시간 서식입니다. 가능한 값은 다음을 포함합니다.
+ - "`full`"
+ - "`long`"
+ - "`medium`"
+ - "`short`"
+
+ > **참고:** `timeStyle`은 `dateStyle`과 함께 사용할 수 있지만, 다른 옵션인 `weekday`, `hour`, `month` 등과는 함께 사용할 수 없습니다.
+
+ - `calendar`
+ - : 역법입니다. "`buddhist`",
+ "`chinese`", " `coptic`", "`ethiopia`",
+ "`ethiopic`", "`gregory`", " `hebrew`",
+ "`indian`", "`islamic`", "`iso8601`", "
+ `japanese`", "`persian`", "`roc`" 등을 사용할 수 있습니다.
+
+ - `dayPeriod`
+ - : (영어의 경우) "in the morning", "am", "noon", "n"처럼 시간의 위치를 나타낼 때 사용할 시간 서식입니다. "`narrow`", "`short`", " `long`" 등을 사용할 수 있습니다.
+
+ > **참고:**
+ >
+ > - 12시간제 형식을 사용할 때만 결과의 차이가 있습니다.
+ > - 한국어를 포함해, 많은 로케일에서는 지정한 너비에 상관하지 않고 같은 문자열을 반환합니다. ("새벽", "밤" 등)
+
+ - `numberingSystem`
+ - : 기수법입니다. "`arab`",
+ "`arabext`", " `bali`", "`beng`",
+ "`deva`", "`fullwide`", " `gujr`",
+ "`guru`", "`hanidec`", "`khmr`", "
+ `knda`", "`laoo`", "`latn`",
+ "`limb`", "`mlym`", " `mong`",
+ "`mymr`", "`orya`", "`tamldec`", "
+ `telu`", "`thai`", "`tibt`" 등을 사용할 수 있습니다.
+
+ - `localeMatcher`
+ - : 로케일 매칭 알고리즘입니다. 가능한 값은 "`lookup`", "`best fit`"이며 기본 값은 "`best fit`"입니다. 자세한 정보는 {{jsxref("Intl", "Intl", "#로케일_조정", 1)}} 문서를 참고하세요.
+
+ - `timeZone`
+ - : 시간대입니다. 구현체가 반드시 인식해야 하는 유일한 값은 "`UTC`"입니다. 기본 값은 런타임의 기본 시간대입니다. 구현체에 따라 "`Asia/Seoul`", "`Asia/Kolkata`",
+ "`America/New_York`"처럼 [IANA 시간대 데이터베이스](https://www.iana.org/time-zones)의 시간대 이름을 인식할 수도 있습니다.
+
+ - `hour12`
+ - : 24시간제 대신 12시간제를 사용할지에 대한 여부입니다. 가능한 값은 `true` 또는 `false`입니다. 기본 값은 로케일에 따라 다릅니다. 이 값은 언어 태그의 `hc`, 옵션 중 `hourCycle`보다 우선합니다.
+
+ - `hourCycle`
+ - : 시간제입니다. "`h11`",
+ "`h12`", "`h23`", "`h24`" 등을 사용할 수 있습니다. 이 값은 언어 태그의 `hc`보다 우선하며, `hour12`가 이 값보다 우선합니다.
+
+ - `formatMatcher`
+ - : 서식 매칭 알고리즘입니다. 가능한 값은 "`basic`", "`best fit`"이며 기본 값은 "`best fit`"입니다. 자세한 설명은 아래 내용을 참고하세요.
+
+ 이하 속성은 서식 출력 결과가 사용할 날짜 및 시간 구성요소를 나타냅니다. 구현체는 적어도 아래의 구성요소 조합을 지원해야 합니다.
+
+ - `weekday`, `year`, `month`, `day`, `hour`, `minute`, `second`
+ - `weekday`, `year`, `month`, `day`
+ - `year`, `month`, `day`
+ - `year`, `month`
+ - `month`, `day`
+ - `hour`, `minute`, `second`
+ - `hour`, `minute`
+
+ 구현체에 따라 다른 구성요소 조합을 지원할 수도 있습니다. 시간 서식을 요청하면, 현재 구현체가 지원하는 모든 구성요소 조합 중 최적 조합을 탐색해 사용합니다. 탐색 알고리즘은 `formatMatcher` 옵션 속성을 사용해 지정할 수 있고, [명세에 완벽히 정의된 "`basic`" 알고리즘](https://402.ecma-international.org/1.0/#BasicFormatMatcher)과 구현체에 따라 다른 "`best-fit`" 알고리즘의 두 종류가 있습니다.
+
+ - `weekday`
+
+ - : 요일. 가능한 값은 다음과 같습니다.
+
+ - "`long`" (`금요일`, `Thursday` 등)
+ - "`short`" (`(금)`, `Thu` 등)
+ - "`narrow`" (`(금)`, `T` 등). 일부 로케일에서는 두 개의 요일이 같은 값을 스타일을 가질 수 있습니다. (예: `Thursday`와 `Tuesday` 둘 다 `T`)
+
+ - `era`
+
+ - : 시대. 가능한 값은 다음과 같습니다.
+
+ - "`long`" (`서기`, `Anno Domini` 등)
+ - "`short`" (`AD` 등)
+ - "`narrow`" (`A`, `AD` 등)
+
+ - `year`
+
+ - : 연도. 가능한 값은 다음과 같습니다.
+
+ - "`numeric`" (`2019년`, `2019` 등)
+ - "`2-digit`" (`19년`, `19` 등)
+
+ - `month`
+
+ - : 월. 가능한 값은 다음과 같습니다.
+
+ - "`numeric`" (`3` 등)
+ - "`2-digit`" (`03` 등)
+ - "`long`" (`3월`, `March` 등)
+ - "`short`" (`Mar` 등)
+ - "`narrow`" (`M` 등). 일부 로케일에서는 두 개의 요일이 같은 값을 스타일을 가질 수 있습니다. (예: `March`와 `May` 둘 다 `M`)
+
+ - `day`
+
+ - : 일. 가능한 값은 다음과 같습니다.
+
+ - "`numeric`" (`1` 등)
+ - "`2-digit`" (`01` 등)
+
+ - `hour`
+ - : 시. 가능한 값은 `"numeric"`, `"2-digit"`입니다.
+ - `minute`
+ - : 분. 가능한 값은 `"numeric"`, `"2-digit"`입니다.
+ - `second`
+ - : 초. 가능한 값은 `"numeric"`, `"2-digit"`입니다.
+ - `fractionalSecondDigits`
+
+ - : 밀리초를 나타낼 소숫점 이하 자릿수. 가능한 값은 다음과 같습니다.
+
+ - `0` (밀리초를 표시하지 않음.)
+ - `1` (밀리초를 한 자리까지 표시함. 예를 들어, 0.736초는 7까지 보입니다.)
+ - `2` (밀리초를 두 자리까지 표시함. 예를 들어, 0.736초는 73로 보입니다.)
+ - `3` (밀리초를 세 자리까지 표시함. 예를 들어, 0.736초는 736으로 보입니다.)
+
+ - `timeZoneName`
+
+ - : 시간대 이름. 가능한 값은 다음과 같습니다.
+
+ - "`long`" 지역화된 긴 시간대 이름 (`한국 표준시`, `British Summer Time`)
+ - "`short`" 지역화된 짧은 시간대 이름 (`PST`, `GMT+9`)
+ - "`shortOffset`" 지역화된 GMT 형식 (`GMT-8`, `GMT+9`)
+ - "`longOffset`" 지역화된 긴 GMT 형식 (`GMT+0900`)
+ - "`shortGeneric`" 지역을 특정하지 않는 일반적인 형식 (`PT`)
+ - "`longGeneric`" 지역을 특정하지 않는 긴 일반적인 형식 (`Pacific Time`)
+
+ > **참고:** 요구한 형식을 사용할 수 없을 경우 시간대 서식이 다른 형태로 대체될 수 있습니다. 예를 들어 지역을 특정하지 않는 서식의 경우 특정 국가나 도시 이름을 포함하지 않아야 하지만, "Los Angeles Time"처럼 필요할 경우 이름을 포함할 수 있습니다.
+
+ 각 구성요소 속성의 기본값은 {{jsxref("undefined")}}입니다. 그러나 모든 속성이 `undefined`일 경우, `year`, `month`, `day`는 "`numeric`"으로 취급합니다.
+
+## 예제
+
+### DateTimeFormat 사용하기
+
+로케일을 지정하지 않고 사용하면 기본 로케일 및 기본 옵션 서식을 적용한 문자열을 반환합니다.
+
+```js
+var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
+
+// 매개변수 없이 toLocaleString() 호출한 결과는
+// 구현체, 기본 로케일, 기본 시간대에 다라 달라짐
+console.log(new Intl.DateTimeFormat().format(date));
+// → ko-KR 로케일(언어)와 Asia/Seoul 시간대(UTC+0900)에서 "2012. 12. 20."
+```
+
+### timeStyle과 dateStyle 사용하기
+
+다음 예제는 지역화된 숫자 서식의 예시를 보입니다. 어플리케이션의 사용자 인터페이스 언어에 맞는 서식을 적용하려면 `locales` 매개변수로 적절한 언어(와, 필요한 경우 대체 언어)를 제공하는걸 잊지 마세요.
+
+```js
+let o = new Intl.DateTimeFormat("en" , {
+ timeStyle: "short"
+});
+console.log(o.format(Date.now())); // "13:31 AM"
+
+let o = new Intl.DateTimeFormat("en" , {
+ dateStyle: "short"
+});
+console.log(o.format(Date.now())); // "07/07/20"
+
+let o = new Intl.DateTimeFormat("en" , {
+ timeStyle: "medium",
+ dateStyle: "short"
+});
+console.log(o.format(Date.now())); // "07/07/20, 13:31:55 AM"
+```
+
+### timeZoneName 사용하기
+
+`timeZoneName`을 사용하면 시간대도 결과에 포함할 수 있습니다.
+
+```js
+var date = Date.UTC(2021, 11, 17, 3, 0, 42);
+const timezoneNames = ['short', 'long', 'shortOffset', 'longOffset', 'shortGeneric', 'longGeneric']
+
+for (const zoneName of timezoneNames) {
+ var formatter = new Intl.DateTimeFormat('en-US', {
+ timeZone: 'America/Los_Angeles',
+ timeZoneName: zoneName,
+ });
+ console.log(zoneName + ": " + formatter.format(date) );
+}
+
+// 예상 출력 결과:
+// > "short: 12/16/2021, PST"
+// > "long: 12/16/2021, Pacific Standard Time"
+// > "shortOffset: 12/16/2021, GMT-8"
+// > "longOffset: 12/16/2021, GMT-08:00"
+// > "shortGeneric: 12/16/2021, PT"
+// > "longGeneric: 12/16/2021, Pacific Time"
+```
+
+## 명세
+
+{{Specifications}}
+
+## 브라우저 호환성
+
+{{Compat}}
+
+## 같이 보기
+
+- {{jsxref("Intl.DateTimeFormat")}}
+- {{jsxref("Global_Objects/Intl", "Intl")}}
diff --git a/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/index.md b/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/index.md
index deb61cb636..6dcaaa0200 100644
--- a/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/index.md
+++ b/files/ko/web/javascript/reference/global_objects/intl/datetimeformat/index.md
@@ -2,200 +2,66 @@
title: Intl.DateTimeFormat
slug: Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat
tags:
+ - Class
- DateTimeFormat
- Internationalization
- Intl
- JavaScript
+ - Localization
- Reference
+browser-compat: javascript.builtins.Intl.DateTimeFormat
translation_of: Web/JavaScript/Reference/Global_Objects/Intl/DateTimeFormat
---
-<div>{{JSRef}}</div>
-
-<p><span class="seoSummary"><strong><code>Intl.DateTimeFormat</code></strong>은 언어에 맞는 날짜 및 시간 서식을 지원하는 객체의 생성자입니다.</span> <code>dateStyle</code>과 <code>timeStyle</code> 옵션을 통해 날짜와 시간 형식을 빠르게 맞출 수 있고, 더 자세한 조정을 위한 다른 옵션도 존재합니다.</p>
-
-<div>{{EmbedInteractiveExample("pages/js/intl-datetimeformat.html")}}</div>
-
-
-
-<h2 id="구문">구문</h2>
-
-<pre class="syntaxbox">new Intl.DateTimeFormat([<var>locales</var>[, <var>options</var>]])
-Intl.DateTimeFormat.call(<var>this</var>[, <var>locales</var>[, <var>options</var>]])</pre>
-
-<h3 id="매개변수">매개변수</h3>
-
-<dl>
- <dt><code>locales</code> {{optional_inline}}</dt>
- <dd>
- <p><a href="https://ko.wikipedia.org/wiki/IETF_%EC%96%B8%EC%96%B4_%ED%83%9C%EA%B7%B8">BCP 47</a> 언어 태그를 포함하는 문자열이나 문자열의 배열. 로케일 매개변수의 일반적인 형식 및 해석은 {{jsxref("Intl", "<code>Intl</code> 문서", "#Locale_identification_and_negotiation", 1)}}를 참고하세요. 다음의 유니코드 확장 키를 사용할 수 있습니다.</p>
-
- <dl>
- <dt><code>nu</code></dt>
- <dd>사용할 기수법. <code>"arab"</code>, <code>"arabext"</code>, <code>"bali"</code>, <code>"beng"</code>, <code>"deva"</code>, <code>"fullwide"</code>, <code>"gujr"</code>, <code>"guru"</code>, <code>"hanidec"</code>, <code>"khmr"</code>, <code>"knda"</code>, <code>"laoo"</code>, <code>"latn"</code>, <code>"limb"</code>, <code>"mlym"</code>, <code>"mong"</code>, <code>"mymr"</code>, <code>"orya"</code>, <code>"tamldec"</code>, <code>"telu"</code>, <code>"thai"</code>, <code>"tibt"</code> 등을 사용할 수 있습니다.</dd>
- <dt><code>ca</code></dt>
- <dd>역법. <code>"buddhist"</code>, <code>"chinese"</code>, <code>"coptic"</code>, <code>"ethioaa"</code>, <code>"ethiopic"</code>, <code>"gregory"</code>, <code>"hebrew"</code>, <code>"indian"</code>, <code>"islamic"</code>, <code>"islamicc"</code>, <code>"iso8601"</code>, <code>"japanese"</code>, <code>"persian"</code>, <code>"roc"</code> 등을 사용할 수 있습니다.</dd>
- <dt><code>hc</code></dt>
- <dd>시간 사이클. <code>"h11"</code>, <code>"h12"</code>, <code>"h23"</code>, <code>"h24"</code> 등을 사용할 수 있습니다.</dd>
- </dl>
- </dd>
- <dt><code>options</code> {{optional_inline}}</dt>
- <dd>
- <p>다음 속성을 포함하는 객체.</p>
-
- <dl>
- <dt><code>dateStyle</code></dt>
- <dd><code>format()</code>을 호출했을 때 사용할 날짜 서식. 가능한 값은 다음을 포함합니다.
- <ul>
- <li><code>"full"</code></li>
- <li><code>"long"</code></li>
- <li><code>"medium"</code></li>
- <li><code>"short"</code></li>
- </ul>
- </dd>
- <dt><code>timeStyle</code></dt>
- <dd><code>format()</code>을 호출했을 때 사용할 시간 서식. 가능한 값은 다음을 포함합니다.
- <ul>
- <li><code>"full"</code></li>
- <li><code>"long"</code></li>
- <li><code>"medium"</code></li>
- <li><code>"short"</code></li>
- </ul>
- </dd>
- <dt><code>localeMatcher</code></dt>
- <dd>사용할 로케일 매칭 알고리즘. 가능한 값은 <code>"lookup"</code>과 <code>"best fit"</code>이고, 기본값은 <code>"best fit"</code>입니다. 자세한 정보는 {{jsxref("Intl", "<code>Intl</code> 문서", "#로케일_조정", 1)}}를 참고하세요.</dd>
- <dt><code>timeZone</code></dt>
- <dd>사용할 시간대. 구현체가 반드시 인식해야 하는 유일한 값은 <code>"UTC"</code>입니다. 기본값은 런타임의 기본 시간대입니다. 구현체에 따라 "<code>Asia/Shanghai</code>", "<code>Asia/Kolkata</code>", "<code>America/New_York</code>" 등 <a href="https://www.iana.org/time-zones">IANA 시간대 데이터베이스</a>의 시간대 이름을 인식할 수도 있습니다.</dd>
- <dt><code>hour12</code></dt>
- <dd>24시간제 대신 12시간제를 사용할지 여부. 가능한 값은 <code>true</code> 와 <code>false</code>이고, 기본값은 로케일에 따라 다릅니다. 이 옵션을 지정하면 <code>hc</code> 언어 태그와 <code>hourCycle</code> 옵션을 모두 무시합니다.</dd>
- <dt><code>hourCycle</code></dt>
- <dd>사용할 시간제. 가능한 값은 <code>"h11"</code>, <code>"h12"</code>, <code>"h23"</code>, <code>"h24"</code>입니다. 이 옵션을 지정하면 <code>hc</code> 언어 태그를 무시합니다. <code>hour12</code> 옵션을 지정한 경우 그 값이 우선순위를 가집니다.</dd>
- <dt><code>formatMatcher</code></dt>
- <dd>사용할 서식 매칭 알고리즘. 가능한 값은 <code>"basic"</code>과 <code>"best fit"</code>이고, 기본값은 <code>"best fit"</code>입니다. 아래의 단락에서 이 속성의 자세한 정보를 확인하세요.</dd>
- </dl>
-
- <p>이후의 속성은 서식을 적용한 출력 결과가 사용할 날짜 및 시간 구성요소를 나타냅니다. 구현체는 적어도 아래의 부분집합을 지원해야 합니다.</p>
-
- <ul>
- <li><code>weekday</code>, <code>year</code>, <code>month</code>, <code>day</code>, <code>hour</code>, <code>minute</code>, <code>second</code></li>
- <li><code>weekday</code>, <code>year</code>, <code>month</code>, <code>day</code></li>
- <li><code>year</code>, <code>month</code>, <code>day</code></li>
- <li><code>year</code>, <code>month</code></li>
- <li><code>month</code>, <code>day</code></li>
- <li><code>hour</code>, <code>minute</code>, <code>second</code></li>
- <li><code>hour</code>, <code>minute</code></li>
- </ul>
-
- <p>구현체에 따라 다른 집합을 지원할 수도 있습니다. 서식 요청은 가능한 모든 부분집합 조합 중 최적으로 일치하는 집합으로 조정됩니다. 조정 알고리즘에는 <a href="http://www.ecma-international.org/ecma-402/1.0/#BasicFormatMatcher">명세에 완벽히 정의된 <code>basic</code> 알고리즘</a>과, 구현체에 따라 다른 <code>best-fit</code> 알고리즘 두 종류가 있으며 <code>formatMatcher</code> 속성의 값이 어느 쪽을 사용할지 결정합니다.</p>
-
- <dl>
- <dt><code>weekday</code></dt>
- <dd>요일. 가능한 값은 다음과 같습니다.
- <ul>
- <li>"<code>long</code>" (<code>금요일</code>, <code>Thursday</code> 등)</li>
- <li>"<code>short</code>" (<code>(금)</code>, <code>Thu</code> 등)</li>
- <li>"<code>narrow</code>" (<code>(금)</code>, <code>T</code> 등). 일부 로케일에서는 두 개의 요일이 같은 값을 스타일을 가질 수 있습니다. (예: <code>Thursday</code>와 <code>Tuesday</code> 둘 다 <code>T</code>)</li>
- </ul>
- </dd>
- <dt><code>era</code></dt>
- <dd>시대. 가능한 값은 다음과 같습니다.
- <ul>
- <li>"<code>long</code>" (<code>서기</code>, <code>Anno Domini</code> 등)</li>
- <li>"<code>short</code>" (<code>AD</code> 등)</li>
- <li>"<code>narrow</code>" (<code>A</code>, <code>AD</code> 등)</li>
- </ul>
- </dd>
- <dt><code>year</code></dt>
- <dd>연도. 가능한 값은 다음과 같습니다.
- <ul>
- <li>"<code>numeric</code>" (<code>2019년</code>, <code>2019</code> 등)</li>
- <li>"<code>2-digit</code>" (<code>19년</code>, <code>19</code> 등)</li>
- </ul>
- </dd>
- <dt><code>month</code></dt>
- <dd>월. 가능한 값은 다음과 같습니다.
- <ul>
- <li>"<code>numeric</code>" (<code>3</code> 등)</li>
- <li>"<code>2-digit</code>" (<code>03</code> 등)</li>
- <li>"<code>long</code>" (<code>3월</code>, <code>March</code> 등)</li>
- <li>"<code>short</code>" (<code>Mar</code> 등)</li>
- <li>"<code>narrow</code>" (<code>M</code> 등). 일부 로케일에서는 두 개의 요일이 같은 값을 스타일을 가질 수 있습니다. (예: <code>March</code>와 <code>May</code> 둘 다 <code>M</code>)</li>
- </ul>
- </dd>
- <dt><code>day</code></dt>
- <dd>일. 가능한 값은 다음과 같습니다.
- <ul>
- <li>"<code>numeric</code>" (<code>1</code> 등)</li>
- <li>"<code>2-digit</code>" (<code>01</code> 등)</li>
- </ul>
- </dd>
- <dt><code>hour</code></dt>
- <dd>시. 가능한 값은 <code>"numeric"</code>, <code>"2-digit"</code>입니다.</dd>
- <dt><code>minute</code></dt>
- <dd>분. 가능한 값은 <code>"numeric"</code>, <code>"2-digit"</code>입니다.</dd>
- <dt><code>second</code></dt>
- <dd>초. 가능한 값은 <code>"numeric"</code>, <code>"2-digit"</code>입니다.</dd>
- <dt><code>timeZoneName</code></dt>
- <dd>시간대 이름. 가능한 값은 다음과 같습니다.
- <ul>
- <li>"<code>long</code>" (<code>한국 표준시</code>, <code>British Summer Time</code>등)</li>
- <li>"<code>short</code>" (<code>GMT+9</code> 등)</li>
- </ul>
- </dd>
- </dl>
-
- <p>각 구성요소 속성의 기본값은 {{jsxref("undefined")}}입니다. 그러나 모든 속성이 {{jsxref("undefined")}}일 경우, <code>year</code>, <code>month</code>, <code>day</code>는 <code>"numeric"</code>으로 취급합니다.</p>
- </dd>
-</dl>
-
-<h2 id="설명">설명</h2>
-
-<h3 id="속성">속성</h3>
-
-<dl>
- <dt>{{jsxref("DateTimeFormat.prototype", "Intl.DateTimeFormat.prototype")}}</dt>
- <dd>모든 인스턴스에 속성을 추가할 수 있습니다.</dd>
-</dl>
-
-<h3 id="메서드">메서드</h3>
-
-<dl>
- <dt>{{jsxref("DateTimeFormat.supportedLocalesOf", "Intl.DateTimeFormat.supportedLocalesOf()")}}</dt>
- <dd>주어진 로케일 목록 중, 런타임이 지원하는 항목을 배열로 반환합니다.</dd>
-</dl>
-
-<h2 id="DateTimeFormat_인스턴스"><code>DateTimeFormat</code> 인스턴스</h2>
-
-<h3 id="속성_2">속성</h3>
-
-<p><code>DateTimeFormat</code> 인스턴스는 프로토타입의 다음 속성을 상속합니다.</p>
-
-<div>{{page('/ko/docs/Web/JavaScript/Reference/Global_Objects/DateTimeFormat/prototype', '속성')}}</div>
-
-<h3 id="메서드_2">메서드</h3>
-
-<p><code>DateTimeFormat</code> 인스턴스는 프로토타입의 다음 메서드를 상속합니다.</p>
-
-<div>{{page('/ko/docs/Web/JavaScript/Reference/Global_Objects/DateTimeFormat/prototype', '메서드')}}</div>
-
-<h2 id="예제">예제</h2>
-
-<h3 id="DateTimeFormat_사용하기"><code>DateTimeFormat</code> 사용하기</h3>
-
-<p>로케일을 지정하지 않고 사용하면 기본 로케일 및 기본 옵션 서식을 적용한 문자열을 반환합니다.</p>
-
-<pre class="brush: js">var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
-
-// 매개변수 없이 toLocaleString() 호출한 결과는
+{{JSRef}}
+
+**`Intl.DateTimeFormat`**은 언어에 맞는 날짜 및 시간 서식을 적용하기 위한 객체입니다.
+
+{{EmbedInteractiveExample("pages/js/intl-datetimeformat.html")}}
+
+## 생성자
+
+- {{jsxref("Intl/DateTimeFormat/DateTimeFormat", "Intl.DateTimeFormat()")}}
+ - : 새로운 `Intl.DateTimeFormat` 객체를 생성합니다.
+
+## 정적 메서드
+
+- {{jsxref("Intl/DateTimeFormat/supportedLocalesOf", "Intl.DateTimeFormat.supportedLocalesOf()")}}
+ - : 매개변수로 제공한 로케일 목록 중, 런타임이 현재 지원하는 로케일 항목을 배열로 반환합니다.
+
+## 인스턴스 메서드
+
+- {{jsxref("Intl/DateTimeFormat/format", "Intl.DateTimeFormat.prototype.format()")}}
+ - : `DateTimeFormat` 객체의 로케일과 서식 옵션에 맞춰 날짜를 서식화해 반환합니다.
+- {{jsxref("Intl/DateTimeFormat/formatToParts", "Intl.DateTimeFormat.prototype.formatToParts()")}}
+ - : 날짜 서식 문자열의 각 부분을 분해하여 토큰 객체로 만들고 {{jsxref("Array")}}로 반환합니다. 로케일에 따라 다른 사용자 지정 서식을 적용할 때 사용할 수 있습니다.
+- {{jsxref("Intl/DateTimeFormat/resolvedOptions", "Intl.DateTimeFormat.prototype.resolvedOptions()")}}
+ - : `DateTimeFormat` 객체를 초기화할 때 할당된 로케일 및 서식 옵션의 계산 값을 나타내는 객체를 반환합니다.
+- {{jsxref("Intl/DateTimeFormat/formatRange", "Intl.DateTimeFormat.prototype.formatRange()")}}
+ - : 두 개의 [Dates](/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date)를 받은 후, 현재 할당된 로케일과 옵션 내에서 가장 간결한 형태로 두 날짜의 범위를 나타내는 문자열을 반환합니다.
+- {{jsxref("Intl/DateTimeFormat/formatRangeToParts", "Intl.DateTimeFormat.prototype.formatRangeToParts()")}}
+ - : 두 개의 [Dates](/en-US/docs/Web/JavaScript/Reference/Global_Objects/Date)를 받은 후, 현재 할당된 로케일과 옵션 내에서 가장 간결한 형태로 두 날짜의 범위를 나타내는 문자열을 생성합니다. 문자열의 각 부분을 분해하여 토큰 객체로 만들고 {{jsxref("Array")}}로 반환합니다.
+
+## 예제
+
+### `DateTimeFormat` 사용하기
+
+로케일을 지정하지 않고 사용하면 기본 로케일과 기본 옵션의 서식을 적용한 문자열을 반환합니다.
+
+```js
+var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
+
+// 매개변수 없이 toLocaleString()을 호출한 결과는
// 구현체, 기본 로케일, 기본 시간대에 다라 달라짐
console.log(new Intl.DateTimeFormat().format(date));
-// → ko-KR 로케일(언어)와 Asia/Seoul 시간대(UTC+0900)에서 "2012. 12. 20."
-</pre>
+// → ko-KR 로케일(언어)과 Asia/Seoul 시간대(UTC+0900)에서 "2012. 12. 20."
+```
-<h3 id="locales_사용하기"><code>locales</code> 사용하기</h3>
+### 로케일 지정하기
-<p>다음 예제는 지역화된 숫자 서식의 예시를 보입니다. 어플리케이션의 사용자 인터페이스 언어에 맞는 서식을 적용하려면 <code>locales</code> 매개변수로 적절한 언어(와, 필요한 경우 대체 언어)를 제공하는걸 잊지 마세요.</p>
+다음 예제는 지역화된 숫자 서식 방법을 보여줍니다. 사용자의 언어에 적합한 서식을 적용하려면 `locales` 매개변수로 해당 언어(필요한 경우 대체 언어까지)를 제공하는 걸 잊지 마세요.
-<pre class="brush: js">var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
+```js
+var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
// 아래 결과는 모두 Asia/Seoul 시간대를 사용한 결과 (UTC+0900, 한국 표준시)
@@ -224,13 +90,14 @@ console.log(new Intl.DateTimeFormat('ja-JP-u-ca-japanese').format(date));
// 다음과 같이 대체 언어를 지정할 수 있음. 아래의 경우 대체 언어는 인도어
console.log(new Intl.DateTimeFormat(['ban', 'id']).format(date));
// → "20/12/2012"
-</pre>
+```
-<h3 id="options_사용하기"><code>options</code> 사용하기</h3>
+### 옵션 지정하기
-<p><code>options</code> 매개변수를 지정해 날짜와 시간 서식 결과를 원하는 형태로 바꿀 수 있습니다.</p>
+`options` 매개변수를 지정하면 날짜와 시간 서식 결과를 원하는 형태로 바꿀 수 있습니다.
-<pre class="brush: js">var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
+```js
+var date = new Date(Date.UTC(2012, 11, 20, 3, 0, 0));
// 긴 날짜 서식에 더해 요일 요청
var options = { weekday: 'long', year: 'numeric', month: 'long', day: 'numeric' };
@@ -261,43 +128,25 @@ options = {
};
console.log(new Intl.DateTimeFormat('en-US', options).format(date));
// → "12/19/2012, 19:00:00"
-</pre>
-
-<h2 id="명세">명세</h2>
-
-<table class="standard-table">
- <tbody>
- <tr>
- <th scope="col">Specification</th>
- <th scope="col">Status</th>
- <th scope="col">Comment</th>
- </tr>
- <tr>
- <td>{{SpecName('ES Int 1.0', '#sec-12.1', 'Intl.DateTimeFormat')}}</td>
- <td>{{Spec2('ES Int 1.0')}}</td>
- <td>Initial definition.</td>
- </tr>
- <tr>
- <td>{{SpecName('ES Int 2.0', '#sec-12.1', 'Intl.DateTimeFormat')}}</td>
- <td>{{Spec2('ES Int 2.0')}}</td>
- <td></td>
- </tr>
- <tr>
- <td>{{SpecName('ES Int Draft', '#datetimeformat-objects', 'Intl.DateTimeFormat')}}</td>
- <td>{{Spec2('ES Int Draft')}}</td>
- <td></td>
- </tr>
- </tbody>
-</table>
-
-<h2 id="브라우저_호환성">브라우저 호환성</h2>
-
-<div>
-
-
-<p>{{Compat("javascript.builtins.Intl.DateTimeFormat")}}</p>
-</div>
-
-<h2 id="같이_보기">같이 보기</h2>
-
-<div>{{page('/ko/docs/Web/JavaScript/Reference/Global_Objects/Intl', '같이_보기')}}</div>
+
+// 옵션을 지정하면서 로케일은 브라우저 기본값을 사용하고 싶을 땐 'default' 지정
+console.log(new Intl.DateTimeFormat('default', options).format(date));
+// → "2012. 12. 19. 19시 0분 0초"
+
+// 오전/오후 시간 표시가 필요할 때
+options = {hour: "numeric", dayPeriod: "short"};
+console.log(new Intl.DateTimeFormat('en-US', options).format(date));
+// → 10 at night
+```
+
+## 명세
+
+{{Specifications}}
+
+## 브라우저 호환성
+
+{{Compat}}
+
+## 같이 보기
+
+- {{jsxref("Intl")}}