Date.now()
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
Die statische Methode Date.now()
gibt die Anzahl der Millisekunden zurück, die seit der Epoche vergangen sind. Diese ist definiert als Mitternacht zu Beginn des 1. Januar 1970 (UTC).
Probieren Sie es aus
// This example takes 2 seconds to run
const start = Date.now();
console.log("starting timer...");
// Expected output: "starting timer..."
setTimeout(() => {
const millis = Date.now() - start;
console.log(`seconds elapsed = ${Math.floor(millis / 1000)}`);
// Expected output: "seconds elapsed = 2"
}, 2000);
Syntax
Date.now()
Parameter
Keine.
Rückgabewert
Eine Zahl, die den Timestamp in Millisekunden der aktuellen Zeit repräsentiert.
Beschreibung
Reduzierte Zeitpräzision
Um Schutz vor Timing-Angriffen und Fingerprinting zu bieten, kann die Präzision von Date.now()
abhängig von den Browsereinstellungen gerundet werden. In Firefox ist die Einstellung privacy.reduceTimerPrecision
standardmäßig aktiviert und hat einen Default-Wert von 2 ms. Sie können auch privacy.resistFingerprinting
aktivieren; in diesem Fall beträgt die Präzision 100 ms oder den Wert von privacy.resistFingerprinting.reduceTimerPrecision.microseconds
, je nachdem, welcher größer ist.
Zum Beispiel gibt das Ergebnis von Date.now()
bei reduzierter Zeitpräzision stets ein Vielfaches von 2 zurück oder bei aktiviertem privacy.resistFingerprinting
ein Vielfaches von 100 (oder privacy.resistFingerprinting.reduceTimerPrecision.microseconds
).
// reduced time precision (2ms) in Firefox 60
Date.now();
// Might be:
// 1519211809934
// 1519211810362
// 1519211811670
// …
// reduced time precision with `privacy.resistFingerprinting` enabled
Date.now();
// Might be:
// 1519129853500
// 1519129858900
// 1519129864400
// …
Beispiele
Messung der verstrichenen Zeit
Sie können Date.now()
verwenden, um die aktuelle Zeit in Millisekunden zu erhalten, und dann eine frühere Zeit subtrahieren, um festzustellen, wie viel Zeit zwischen den beiden Aufrufen verstrichen ist.
const start = Date.now();
doSomeLongRunningProcess();
console.log(`Time elapsed: ${Date.now() - start} ms`);
Für komplexere Szenarien könnten Sie die Performance API verwenden.
Spezifikationen
Specification |
---|
ECMAScript® 2025 Language Specification # sec-date.now |
Browser-Kompatibilität
BCD tables only load in the browser