Intl.DateTimeFormat.prototype.format()

The Intl.DateTimeFormat.prototype.format() メソッドは、この Intl.DateTimeFormat オブジェクトのロケールと整形オプションに従って日付や時刻を整形します。

試してみましょう

構文

js
format(date);

引数

date

整形する日付です。

解説

format ゲッター関数は、この Intl.DateTimeFormat オブジェクトのロケールと整形オプションに従って日付や時刻を整形し、文字列に格納します。

format の使用

format ゲッター関数を使用して単一の日付値を整形します。こちらはセルビアの例です。

js
var options = {
  weekday: "long",
  year: "numeric",
  month: "long",
  day: "numeric",
};
var dateTimeFormat = new Intl.DateTimeFormat("sr-RS", options);
console.log(dateTimeFormat.format(new Date()));
// → "недеља, 7. април 2013."

format と map の使用

format ゲッター関数を使用して、配列内のすべての日付を整形することができます。なお、この関数は供給元である Intl.DateTimeFormat に結び付けられているので、直接 Array.prototype.map() に渡すことができます。

js
var a = [new Date(2012, 08), new Date(2012, 11), new Date(2012, 03)];
var options = { year: "numeric", month: "long" };
var dateTimeFormat = new Intl.DateTimeFormat("pt-BR", options);
var formatted = a.map(dateTimeFormat.format);
console.log(formatted.join("; "));
// → "setembro de 2012; dezembro de 2012; abril de 2012"

書式化された日付値を固定値と比較することは避ける

ほとんどの場合、 format() が返す書式は一貫しています。しかし、これは将来的に変更される可能性があり、すべての言語で保証されているわけではありません — 出力のバリエーションは設計上のものであり、仕様上は許容されています。最も注目すべきは、 IE や Edge ブラウザは日付の周りに双方向の制御文字を挿入するため、他のテキストと連結したときに出力テキストが適切に流れることです。

このことから、 format() の結果と固定値を比較することができると期待してはいけません。

js
let d = new Date("2019-01-01T00:00:00.000000Z");
let formattedDate = Intl.DateTimeFormat(undefined, {
  year: "numeric",
  month: "numeric",
  day: "numeric",
  hour: "numeric",
  minute: "numeric",
  second: "numeric",
}).format(d);

"1.1.2019, 01:00:00" === formattedDate;
// true in Firefox and others
// false in IE and Edge

メモ: この StackOverflow のスレッドに詳細や例があります。

仕様書

Specification
ECMAScript Internationalization API Specification
# sec-intl.datetimeformat.prototype.format

ブラウザーの互換性

BCD tables only load in the browser

関連情報