Intl.DurationFormat.prototype.formatToParts()
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Die Methode formatToParts()
von Intl.DurationFormat
Instanzen ermöglicht eine ortsabhängige Formatierung von durch Intl.DurationFormat
Formatierer erzeugten Zeichenfolgen.
Syntax
formatToParts(duration)
Parameter
duration
Optional-
Das zu formatierende Dauerobjekt. Es sollte einige oder alle der folgenden Eigenschaften enthalten:
"months"
,"weeks"
,"days"
,"hours"
,"minutes"
,"seconds"
,"milliseconds"
,"microseconds"
,"nanoseconds"
.
Rückgabewert
Ein Array
von Objekten, die die formatierte Dauer in Teilen enthalten.
Beschreibung
Die Methode formatToParts()
ist nützlich für die benutzerdefinierte Formatierung von Dauerobjekten. Sie gibt ein Array
von Objekten zurück, die die ortsspezifischen Tokens enthalten, aus denen benutzerdefinierte Zeichenfolgen erstellt werden können, wobei die ortsspezifischen Teile erhalten bleiben. Die Struktur, die von der formatToParts()
Methode zurückgegeben wird, sieht folgendermaßen aus:
[
{ type: "integer", value: "7", unit: "hour" },
{ type: "literal", value: " ", unit: "hour" },
{ type: "unit", value: "hr", unit: "hour" },
{ type: "literal", value: ", " },
{ type: "integer", value: "8", unit: "minute" },
{ type: "literal", value: " ", unit: "minute" },
{ type: "unit", value: "min", unit: "minute" },
];
Beispiele
Die formatToParts
-Methode ermöglicht ortsabhängige Formatierung von durch DurationFormat
Formatierer erzeugten Zeichenfolgen, indem sie Ihnen die Zeichenfolge in Teilen bereitstellt:
const duration = {
hours: 7,
minutes: 8,
seconds: 9,
milliseconds: 123,
microseconds: 456,
nanoseconds: 789,
};
new Intl.DurationFormat("en", { style: "long" }).formatToParts(duration);
// Returned value:
[
{ type: "integer", value: "7", unit: "hour" },
{ type: "literal", value: " ", unit: "hour" },
{ type: "unit", value: "hours", unit: "hour" },
{ type: "literal", value: ", " },
{ type: "integer", value: "8", unit: "minute" },
{ type: "literal", value: " ", unit: "minute" },
{ type: "unit", value: "minutes", unit: "minute" },
{ type: "literal", value: ", " },
{ type: "integer", value: "9", unit: "second" },
{ type: "literal", value: " ", unit: "second" },
{ type: "unit", value: "seconds", unit: "second" },
{ type: "literal", value: ", " },
{ type: "integer", value: "123", unit: "millisecond" },
{ type: "literal", value: " ", unit: "millisecond" },
{ type: "unit", value: "milliseconds", unit: "millisecond" },
{ type: "literal", value: ", " },
{ type: "integer", value: "456", unit: "microsecond" },
{ type: "literal", value: " ", unit: "microsecond" },
{ type: "unit", value: "microseconds", unit: "microsecond" },
{ type: "literal", value: " and " },
{ type: "integer", value: "789", unit: "nanosecond" },
{ type: "literal", value: " ", unit: "nanosecond" },
{ type: "unit", value: "nanoseconds", unit: "nanosecond" },
];
Spezifikationen
Specification |
---|
Intl.DurationFormat # sec-Intl.DurationFormat.prototype.formatToParts |
Browser-Kompatibilität
BCD tables only load in the browser