Temporal.PlainYearMonth.prototype.add()
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 add()
Methode von Temporal.PlainYearMonth
Instanzen gibt ein neues Temporal.PlainYearMonth
Objekt zurück, das diesen Jahr-Monat durch eine gegebene Dauer (in einer Form, die durch Temporal.Duration.from()
konvertierbar ist) nach vorne verschoben darstellt.
Syntax
add(duration)
add(duration, options)
Parameter
duration
-
Ein String, ein Objekt oder eine
Temporal.Duration
Instanz, die eine Dauer repräsentiert, die zu diesem Jahr-Monat hinzugefügt werden soll. Sie wird mit demselben Algorithmus wieTemporal.Duration.from()
in einTemporal.Duration
Objekt konvertiert. options
Optional-
Ein Objekt, das die folgende Eigenschaft enthält:
overflow
Optional-
Ein String, der das Verhalten angibt, wenn eine Datumskomponente außerhalb des gültigen Bereichs liegt. Mögliche Werte sind:
"constrain"
(Standard)-
Die Datumskomponente wird eingeschränkt, um im gültigen Bereich zu bleiben.
"reject"
-
Ein
RangeError
wird ausgelöst, wenn die Datumskomponente außerhalb des gültigen Bereichs liegt.
Rückgabewert
Ein neues Temporal.PlainYearMonth
Objekt, das den durch den ursprünglichen PlainYearMonth
angegebenen Jahr-Monat plus der Dauer darstellt.
Beschreibung
Die duration
wird folgendermaßen behandelt:
- Verschieben Sie sich um die Anzahl der Jahre nach vorne und behalten Sie den
monthCode
bei. Wenn dermonthCode
im resultierenden Jahr ungültig ist (unmöglich für Gregorian und ISO 8601, aber möglich für Kalender mit Schaltmonaten), passen wir ihn basierend auf deroverflow
Option an: Fürconstrain
wählen wir einen anderen Monat gemäß den kulturellen Konventionen der Benutzer dieses Kalenders. Da der Schaltmonat meist als Duplikat eines anderen Monats betrachtet wird, wählen wir möglicherweise den Monat, den er dupliziert. - Verschieben Sie sich um die Anzahl der Monate nach vorne und passen Sie das Jahr gegebenenfalls an.
- Für alle Einheiten kleiner als
months
(Wochen, Tage, Stunden, Minuten, Sekunden, Millisekunden, Mikrosekunden, Nanosekunden) werden diese in die Anzahl der Tage umgewandelt. Alle allgemein unterstützten Kalender verwenden Wochen fester Länge, sodass die Anzahl der Wochen einfach in die Anzahl der Tage umgewandelt wird. Wenn die Regel komplexer ist, könnten wir einen Ansatz ähnlich der Verschiebung von Monaten anwenden. Dann verschieben wir uns um diese Anzahl an Tagen nach vorne, beginnend am ersten Tag des Monats, und passen, falls erforderlich, den Monat und das Jahr an. Dauern, die kürzer als die Länge des aktuellen Monats sind, haben daher keinen Effekt.
Der interne Referenztag wird dann als der erste gültige Tag des Monats gewählt, unabhängig vom ursprünglichen Referenztag oder der Anzahl der Tage in der Dauer. Beim gregorianischen Kalender kann es zu keinem Überlauf kommen, da jedes Jahr immer 12 Monate hat und jegliche Erhöhungen, die kleiner als ein Monat sind, einfach ignoriert werden.
Das Hinzufügen einer Dauer ist äquivalent zum Subtrahieren ihrer Negation.
Beispiele
Hinzufügen einer Dauer im ISO 8601 Kalender
const start = Temporal.PlainYearMonth.from("2021-01");
const end = start.add({ years: 1, months: 2, weeks: 3, days: 4 });
console.log(end.toString()); // 2022-03
const end2 = start.add({ years: -1, months: -2, weeks: -3, days: -4 });
console.log(end2.toString()); // 2019-11
const distance = Temporal.PlainYearMonth.from("2020-01").until("2021-01"); // 366 days
const end3 = start.add(distance);
console.log(end3.toString()); // 2022-01
Hinzufügen einer Dauer in einem nicht-ISO Kalender
const start = Temporal.PlainYearMonth.from("2021-02-01[u-ca=chinese]");
console.log(start.toLocaleString("en-US", { calendar: "chinese" })); // 11/2020
console.log(start.toString()); // 2021-01-13[u-ca=chinese]
const end = start.add({ months: 1 });
console.log(end.toLocaleString("en-US", { calendar: "chinese" })); // 12/2020
console.log(end.toString()); // 2021-02-12[u-ca=chinese]
// Adding an extra day has no effect at all
const end2 = start.add({ months: 1, days: 1 });
console.log(end2.toLocaleString("en-US", { calendar: "chinese" })); // 12/2020
// The reference day doesn't change, because it's always the first day of the Chinese month
console.log(end2.toString()); // 2021-02-12[u-ca=chinese]
// Start in a leap month
const start2 = Temporal.PlainYearMonth.from({
year: 5730,
monthCode: "M05L",
calendar: "hebrew",
});
console.log(start2.toLocaleString("en-US", { calendar: "hebrew" })); // Adar I 5730
// End in another leap month
const end3 = start2.add({ years: 3 });
console.log(end3.toLocaleString("en-US", { calendar: "hebrew" })); // Adar I 5733
Hinzufügen einer Dauer mit Overflow
Wenn wir uns um einige Jahre bewegen und der entsprechende Monat in diesem Jahr ungültig ist, passen wir den Monat basierend auf der overflow
Option an.
// Start in a leap month
const start = Temporal.PlainYearMonth.from({
year: 5730,
monthCode: "M05L",
calendar: "hebrew",
});
// Hebrew leap years occur every 2 or 3 years, and 5731 is not a leap year
const end = start.add({ years: 1 });
console.log(end.toLocaleString("en-US", { calendar: "hebrew" })); // Adar 5731
console.log(end.monthCode); // M06
console.log(end.toString()); // 1971-02-26[u-ca=hebrew]
// Any further month additions are based on the clamped year-month
const end2 = start.add({ years: 1, months: 2 });
console.log(end2.monthCode); // M08
console.log(end2.toString()); // 1971-04-26[u-ca=hebrew]
// Compare with the same addition in a different order that results in no overflow:
const end3 = start.add({ months: 2 }).add({ years: 1 });
console.log(end3.monthCode); // M07
console.log(end3.toString()); // 1971-03-27[u-ca=hebrew]
Beachten Sie, dass das Folgende kein Overflow ist, da das Jahr einfach inkrementiert werden kann:
const start = Temporal.PlainYearMonth.from("2021-01");
const end = start.add({ months: 100 });
console.log(end.toString()); // 2029-05
Sie können auch einen Fehler auslösen, wenn die Datumskomponente außerhalb des gültigen Bereichs liegt:
const start = Temporal.PlainYearMonth.from({
year: 5730,
monthCode: "M05L",
calendar: "hebrew",
});
const end = start.add({ years: 1 }, { overflow: "reject" }); // RangeError: invalid "monthCode" calendar field: M05L
Spezifikationen
Specification |
---|
Temporal proposal # sec-temporal.plainyearmonth.prototype.add |
Browser-Kompatibilität
BCD tables only load in the browser