Temporal.ZonedDateTime.prototype.getTimeZoneTransition()
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 Methode getTimeZoneTransition()
von Instanzen des Objekts Temporal.ZonedDateTime
gibt ein Temporal.ZonedDateTime
-Objekt zurück, das den nächstgelegenen Zeitpunkt nach oder vor diesem Moment darstellt, zu dem sich der UTC-Offset der Zeitzone ändert (der zurückgegebene Moment ist der erste Moment nach der Änderung), oder null
, wenn es keinen solchen Übergang gibt. Dies ist nützlich, um die Offset-Regeln einer Zeitzone zu ermitteln, wie zum Beispiel das Muster der Sommerzeit.
Beachten Sie, dass zurückgegebene Momente in der Zukunft möglicherweise nicht zuverlässig sind, zum Beispiel aufgrund von Änderungen in den Zeitzonendefinitionen.
Syntax
getTimeZoneTransition(direction)
getTimeZoneTransition(options)
Parameter
direction
-
Ein String, der die
direction
-Option darstellt. Dies ist eine praktische Überladung, sodassgetTimeZoneTransition(direction)
äquivalent zugetTimeZoneTransition({ direction })
ist, wobeidirection
ein String ist. options
-
Ein Objekt mit der folgenden Eigenschaft:
direction
-
Ob vor oder nach dem aktuellen Moment gesucht werden soll. Muss einer von
"next"
oder"previous"
sein.
Rückgabewert
Ein Temporal.ZonedDateTime
-Objekt mit dem Moment t
, sodass:
- Der Zeitzonenoffset bei
t
sich von dem Offset eine Nanosekunde vort
unterscheidet. t < this.epochNanoseconds
, wenndirection
"previous"
ist, odert > this.epochNanoseconds
, wenndirection
"next"
ist.- Für alle Momente zwischen
this.epochNanoseconds
undt
, ausschließlich, ist der Offset konstant.
Falls es keinen solchen Übergang gibt, wird null
zurückgegeben.
Beispiele
Die nächste Zeitzonenänderung finden
const dt = Temporal.ZonedDateTime.from("2024-01-01T00-05:00[America/New_York]");
const transition = dt.getTimeZoneTransition("next");
console.log(transition.toString()); // "2024-03-10T03:00:00-04:00[America/New_York]"
const transition2 = transition.getTimeZoneTransition("next");
console.log(transition2.toString()); // "2024-11-03T01:00:00-05:00[America/New_York]"
const transition3 = dt.getTimeZoneTransition("previous");
console.log(transition3.toString()); // "2023-11-05T01:00:00-05:00[America/New_York]"
const dt2 = Temporal.ZonedDateTime.from("2024-01-01T00Z[UTC]");
console.log(dt2.getTimeZoneTransition("next")); // null
Spezifikationen
Specification |
---|
Temporal # sec-temporal.zoneddatetime.prototype.gettimezonetransition |