Temporal.PlainDate.prototype.eraYear
Limited availability
This feature is not Baseline because it does not work in some of the most widely-used browsers.
Experimentell: Dies ist eine experimentelle Technologie
Überprüfen Sie die Browser-Kompatibilitätstabelle sorgfältig vor der Verwendung auf produktiven Webseiten.
Die eraYear
Zugriffseigenschaft von Temporal.PlainDate
Instanzen gibt eine nicht-negative Ganzzahl zurück, die das Jahr dieses Datums innerhalb der Ära darstellt, oder undefined
, wenn der Kalender keine Ären verwendet (z.B. ISO 8601). Der Jahresindex beginnt normalerweise bei 1 (häufiger) oder 0, und Jahre in einer Ära können mit der Zeit abnehmen (z.B. Gregorianisches BCE). era
und eraYear
zusammen identifizieren ein Jahr in einem Kalender eindeutig, auf die gleiche Weise wie year
. Es ist kalender-abhängig.
Im Gegensatz zu year
können sich era
und eraYear
in der Mitte eines Kalenderjahres ändern. Zum Beispiel begann die Reiwa-Ära in Japan am 1. Mai 2019, sodass Daten vom 2019-01-01 bis 2019-04-30 { era: "heisei", eraYear: 31 }
haben, und Daten ab dem 2019-05-01 { era: "reiwa", eraYear: 1 }
, aber das year
ist immer 2019 (da der japanische Kalender das ISO 8601-Jahr als Standardjahr verwendet).
Der Set-Zugriff von eraYear
ist undefined
. Sie können diese Eigenschaft nicht direkt ändern. Verwenden Sie die with()
Methode, um ein neues Temporal.PlainDate
-Objekt mit dem gewünschten neuen Wert zu erstellen.
Beispiele
Verwendung von eraYear
const date = Temporal.PlainDate.from("2021-07-01"); // ISO 8601 calendar
console.log(date.eraYear); // undefined
const date2 = Temporal.PlainDate.from("2021-07-01[u-ca=gregory]");
console.log(date2.eraYear); // 2021
const date3 = Temporal.PlainDate.from("-002021-07-01[u-ca=gregory]");
console.log(date3.eraYear); // 2022; 0000 is used for the year 1 BC
const date4 = Temporal.PlainDate.from("2021-07-01[u-ca=japanese]");
console.log(date4.eraYear); // 3
Ändern von eraYear
Sie können eraYear
nur für Kalender festlegen, die sie unterstützen. Zum Beispiel hat der ISO 8601-Kalender keine Ären. Beachten Sie, dass Sie era
und eraYear
zusammen angeben müssen.
const date = Temporal.PlainDate.from("2021-07-01[u-ca=gregory]");
const newDate = date.with({ era: "bc", eraYear: 100 });
console.log(newDate.toString()); // -000099-07-01[u-ca=gregory]
const date2 = Temporal.PlainDate.from("2021-07-01[u-ca=japanese]");
const newDate2 = date2.with({ era: "meiji", eraYear: 1 });
console.log(newDate2.toString()); // 1868-07-01[u-ca=japanese]
Spezifikationen
Specification |
---|
Temporal # sec-get-temporal.plaindate.prototype.erayear |