Temporal.PlainYearMonth.from()
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Die Temporal.PlainYearMonth.from() statische Methode erstellt ein neues Temporal.PlainYearMonth-Objekt aus einem anderen Temporal.PlainYearMonth-Objekt, einem Objekt mit Jahr- und Monatseigenschaften oder einem RFC 9557 String.
Syntax
Temporal.PlainYearMonth.from(info)
Temporal.PlainYearMonth.from(info, options)
Parameter
info-
Eines der folgenden:
- Eine
Temporal.PlainYearMonthInstanz, die eine Kopie der Instanz erstellt. - Ein RFC 9557 String, der ein Datum und optional einen Kalender enthält. Wenn der Kalender nicht
iso8601ist, ist ein Tag erforderlich. - Ein Objekt, das die folgenden Eigenschaften enthält (in der Reihenfolge, in der sie abgerufen und validiert werden):
calendarOptional-
Ein String, der der
calendarIdEigenschaft entspricht. SieheIntl.supportedValuesOf()für eine Liste der allgemein unterstützten Kalenderarten. Standardwert ist"iso8601". Alle anderen Eigenschaften werden in diesem Kalendersystem interpretiert (im Gegensatz zumTemporal.PlainYearMonth()Konstruktor, der die Werte im ISO-Kalendersystem interpretiert). eraunderaYear-
Ein String und ein Integer, die den
eraunderaYearEigenschaften entsprechen. Werden nur verwendet, wenn das Kalendersystem Epochen hat.eraunderaYearmüssen gleichzeitig angegeben werden. Wenn sie nicht angegeben werden, mussyearangegeben werden. Wenn alleera,eraYearundyearangegeben werden, müssen sie übereinstimmen. month-
Entspricht der
monthEigenschaft. Muss positiv sein, unabhängig von deroverflowOption. monthCode-
Entspricht der
monthCodeEigenschaft. Wenn es nicht angegeben wird, mussmonthangegeben werden. Wenn sowohlmonthals auchmonthCodeangegeben werden, müssen sie übereinstimmen. year-
Entspricht der
yearEigenschaft.
- Eine
optionsOptional-
Ein Objekt, das die folgende Eigenschaft enthält:
overflowOptional-
Ein String, der das Verhalten angibt, wenn eine Datumskomponente außerhalb des Bereichs liegt (bei Verwendung des Objekt
info). Mögliche Werte sind:"constrain"(Standard)-
Die Datumskomponente wird auf den gültigen Bereich abgegrenzt.
"reject"-
Ein
RangeErrorwird ausgelöst, wenn die Datumskomponente außerhalb des Bereichs liegt.
Rückgabewert
Ein neues Temporal.PlainYearMonth-Objekt, das das Jahr und den Monat repräsentiert, die durch info im angegebenen calendar bestimmt werden.
Jedes PlainYearMonth speichert intern ein vollständiges ISO 8601-Datum, das denselben Jahr-Monat im Zielkalender hat, wie er angezeigt wird. Der Referenztag ist sichtbar, wenn er mit toString() zu einem ISO-Datum konvertiert wird. Der Referenztag wird willkürlich, aber konsistent gewählt; das heißt, jedes (year, month)-Paar wird immer dem gleichen ISO-Referenztag zugeordnet. Er verwendet nicht den im Eingabewert angegebenen Tag. Stattdessen wird der Referenztag immer als der erste gültige Tag des Monats gewählt.
Diese Referenztag-Kanonisierung stellt sicher, dass equals() die zugrunde liegenden ISO-Daten direkt vergleichen kann, ohne zusätzliche Berechnungen.
Ausnahmen
TypeError-
Wird in einem der folgenden Fälle ausgelöst:
infoist kein Objekt oder String.optionsist kein Objekt oderundefined.- Die bereitgestellten Eigenschaften sind unzureichend, um ein Datum unmissverständlich zu bestimmen. Sie müssen normalerweise ein
year(odereraunderaYear) und einenmonth(oder einenmonthCode) angeben.
RangeError-
Wird in einem der folgenden Fälle ausgelöst:
- Die bereitgestellten Eigenschaften, die dieselbe Komponente angeben, sind inkonsistent.
- Die bereitgestellten nicht-numerischen Eigenschaften sind ungültig; zum Beispiel, wenn
monthCodeniemals ein gültiger Monatscode in diesem Kalender ist. - Die bereitgestellten numerischen Eigenschaften liegen außerhalb des Bereichs, und
options.overflowist auf"reject"gesetzt. - Die Informationen liegen außerhalb des darstellbaren Bereichs, der ±(108 + 1) Tage, oder etwa ±273.972,6 Jahre, ab der Unix-Epoche umfasst.
Beispiele
>Erstellen eines PlainYearMonth aus einem Objekt
// Year + month code
const ym = Temporal.PlainYearMonth.from({ year: 2021, monthCode: "M05" });
console.log(ym.toString()); // 2021-05
// Year + month
const ym2 = Temporal.PlainYearMonth.from({ year: 2021, month: 7 });
console.log(ym2.toString()); // 2021-07
// Year + month in a different calendar
const ym3 = Temporal.PlainYearMonth.from({
year: 5730,
month: 6,
calendar: "hebrew",
});
console.log(ym3.toString()); // 1970-02-07[u-ca=hebrew]
// Year + month code in a different calendar
const ym4 = Temporal.PlainYearMonth.from({
year: 5730,
monthCode: "M05L",
calendar: "hebrew",
});
console.log(ym4.toString()); // 1970-02-07[u-ca=hebrew]
Kontrolle des Überlaufverhaltens
Standardmäßig werden Werte außerhalb des Bereichs auf den gültigen Bereich eingegrenzt.
const ym1 = Temporal.PlainYearMonth.from({ year: 2021, month: 13 });
console.log(ym1.toString()); // 2021-12
// 5732 is not a Hebrew leap year, so a different monthCode is chosen
const ym2 = Temporal.PlainYearMonth.from({
year: 5732,
monthCode: "M05L",
calendar: "hebrew",
});
console.log(ym2.toLocaleString("en-US", { calendar: "hebrew" })); // Adar 5732
const underlyingDate = Temporal.PlainDate.from(ym2.toString());
console.log(underlyingDate.year, underlyingDate.monthCode); // 5732 M06
Sie können dieses Verhalten ändern, damit stattdessen ein Fehler ausgelöst wird:
Temporal.PlainYearMonth.from({ year: 2021, month: 13 }, { overflow: "reject" });
// RangeError: date value "month" not in 1..12: 13
Spezifikationen
| Specification |
|---|
| Temporal> # sec-temporal.plainyearmonth.from> |