Temporal.PlainMonthDay.prototype.day
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 day
Zugriffseigenschaft von Temporal.PlainMonthDay
Instanzen gibt eine positive ganze Zahl zurück, die den 1-basierten Tagesindex im Monat dieses Datums darstellt, was der gleichen Tagesnummer entspricht, die auf einem Kalender angezeigt wird. Sie ist kalender-abhängig.
Der Set-Accessor von day
ist undefined
. Sie können diese Eigenschaft nicht direkt ändern. Verwenden Sie die Methode with()
, um ein neues Temporal.PlainMonthDay
-Objekt mit dem gewünschten neuen Wert zu erstellen.
Für allgemeine Informationen und weitere Beispiele siehe Temporal.PlainDate.prototype.day
.
Beispiele
Verwendung von day
const md = Temporal.PlainMonthDay.from("07-01"); // ISO 8601 calendar
console.log(md.day); // 1
const md2 = Temporal.PlainMonthDay.from("2021-07-01[u-ca=chinese]");
console.log(md2.day); // 22; it is May 22 in the Chinese calendar
Änderung von day
const md = Temporal.PlainMonthDay.from("07-01");
const newMD = md.with({ day: 15 });
console.log(newMD.toString()); // 07-15
Standardmäßig beschränkt with()
den Tag auf den Bereich gültiger Werte. Sie können also { day: 1 }
verwenden, um den Tag auf den ersten Tag des Monats festzulegen, selbst wenn der erste Tag nicht die Zahl 1
hat. Ebenso wird Folgendes den Tag auf den letzten Tag des Monats setzen:
const md = Temporal.PlainMonthDay.from("07-01");
const lastMD = md.with({ day: Number.MAX_VALUE }); // 07-31
Für den Zweck von PlainMonthDay
wird der Februar immer als ein Monat mit 29 Tagen betrachtet.
const md = Temporal.PlainMonthDay.from("02-01");
const lastMD = md.with({ day: Number.MAX_VALUE }); // 02-29
console.log(lastMD.day); // 29
Für andere Kalender gilt, solange ein Jahr existiert, in dem das Monats-Tag gültig ist, wird das Monats-Tag als gültig angesehen, und das zugrunde liegende Referenzjahr kann sich daher ändern. Zum Beispiel:
const md = Temporal.PlainMonthDay.from({
monthCode: "M02",
day: 29,
calendar: "hebrew",
});
console.log(md.toString()); // 1972-11-06[u-ca=hebrew]
console.log(md.toLocaleString("en-US", { calendar: "hebrew" })); // 29 Heshvan
const lastMD = md.with({ day: Number.MAX_VALUE });
// 30 Heshvan does not exist in 1972, so the reference year changes to 1971
console.log(lastMD.toString()); // 1971-11-18[u-ca=hebrew]
console.log(lastMD.toLocaleString("en-US", { calendar: "hebrew" })); // 30 Heshvan
Spezifikationen
Specification |
---|
Temporal # sec-get-temporal.plainmonthday.prototype.day |