Temporal.Instant.compare()

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 statische Methode Temporal.Instant.compare() gibt eine Zahl zurück (-1, 0 oder 1), die angibt, ob der erste Zeitpunkt vor, gleich oder nach dem zweiten Zeitpunkt kommt. Dies entspricht dem Vergleich der epochNanoseconds der beiden Zeitpunkte.

Syntax

js
Temporal.Instant.compare(instant1, instant2)

Parameter

instant1

Ein String oder eine Temporal.Instant Instanz, die den ersten zu vergleichenden Zeitpunkt repräsentiert. Sie wird unter Verwendung desselben Algorithmus wie Temporal.Instant.from() in ein Temporal.Instant Objekt umgewandelt.

instant2

Der zweite zu vergleichende Zeitpunkt, der mit demselben Algorithmus wie instant1 in ein Temporal.Instant Objekt umgewandelt wird.

Rückgabewert

Gibt -1 zurück, wenn instant1 vor instant2 kommt, 0 wenn sie gleich sind, und 1 wenn instant1 nach instant2 kommt.

Beispiele

Nutzung von Temporal.Instant.compare()

js
const instant1 = Temporal.Instant.from("2021-08-01T12:34:56Z");
const instant2 = Temporal.Instant.from("2021-08-01T12:34:56Z");

console.log(Temporal.Instant.compare(instant1, instant2)); // 0

const instant3 = Temporal.Instant.from("2021-08-01T13:34:56Z");
console.log(Temporal.Instant.compare(instant1, instant3)); // -1

Sortieren eines Arrays von Zeitpunkten

Der Zweck dieser compare() Funktion besteht darin, als Comparator zu fungieren, der an Array.prototype.sort() und ähnliche Funktionen übergeben wird.

js
const instants = [
  Temporal.Instant.from("2021-08-01T12:34:56Z"),
  Temporal.Instant.from("2021-08-01T12:34:56+01:00"),
  Temporal.Instant.from("2021-08-01T12:34:56-01:00"),
];

instants.sort(Temporal.Instant.compare);
console.log(instants.map((instant) => instant.toString()));
// [ '2021-08-01T11:34:56Z', '2021-08-01T12:34:56Z', '2021-08-01T13:34:56Z' ]

Spezifikationen

Specification
Temporal proposal
# sec-temporal.instant.compare

Browser-Kompatibilität

BCD tables only load in the browser

Siehe auch