--- title: performance.now() slug: Web/API/Performance/now tags: - API - Referencia - Rendimiento - Web Performance API - metodo translation_of: Web/API/Performance/now ---
{{APIRef("High Resolution Timing")}}

El método performance.now() devuelve un {{domxref("DOMHighResTimeStamp")}}, medido en milisegundos, con una precisión de cinco milésimas de segundo (5 microsegundos).

El valor devuelto representa el tiempo transcurrido desde el tiempo de origen (la propiedad {{domxref("PerformanceTiming.navigationStart")}}). En un web worker, el tiempo de origen es el momento en que se crea su contexto de ejecución (ej. hilo o proceso). En una ventana, es el momento en que el usuario navegó (o confirmó la navegación, si la confirmación fue necesaria) al documento actual. Tenga en cuenta los siguientes puntos:

Sintaxis

t = performance.now();

Ejemplo

var t0 = performance.now();
hacerAlgo();
var t1 = performance.now();
console.log("La llamada a hacerAlgo tardó " + (t1 - t0) + " milisegundos.");

A diferencia de otros datos de tiempo disponibles en JavaScript (por ejemplo Date.now), las marcas de tiempo devueltas por Performance.now() no se limitan a resoluciones de un milisegundo. En su lugar, representan tiempos como números en punto flotante con hasta una precisión de microsegundos.

También a diferencia de Date.now(), los valores devueltos por Performance.now() siempre se incrementan a un ritmo constante, independientemente del sistema de reloj (que podría estar ajustado manualmente o manipulado por software como NTP). De todos modos, performance.timing.navigationStart + performance.now() será aproximadamente igual a Date.now().

Especificaciones

Especificación Estado Comentario
{{SpecName('Highres Time Level 2', '#dom-performance-now', 'performance.now()')}} {{Spec2('Highres Time Level 2')}} Definiciones más estrictas de interfaces y tipos.
{{SpecName('Highres Time', '#dom-performance-now', 'performance.now()')}} {{Spec2('Highres Time')}} Definición inicial

Compatibilidad con navegadores

{{CompatibilityTable}}

Característica Chrome Edge Firefox (Gecko) Internet Explorer Opera Safari
Soporte básico {{CompatChrome("20.0")}} {{property_prefix("webkit")}}
{{CompatChrome("24.0")}} [1]
{{CompatVersionUnknown}} {{CompatGeckoDesktop("15.0")}} 10.0 {{CompatOpera("15.0")}} {{CompatSafari("8.0")}}
en Web workers {{CompatChrome("33")}} {{CompatUnknown}} {{CompatGeckoDesktop("34.0")}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}
now() en un worker dedicado está ahora separado del contexto principal de now(). {{CompatUnknown}} {{CompatUnknown}} {{CompatGeckoDesktop("45.0")}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}
Característica Android Android Webview Edge Firefox Mobile (Gecko) IE Mobile Opera Mobile Safari Mobile Chrome para Android
Soporte básico {{CompatAndroid("4.0")}} {{CompatChrome("25.0")}} {{CompatVersionUnknown}} {{CompatGeckoMobile("15.0")}} 10.0 {{CompatNo}} 9 {{CompatChrome("25.0")}}
en Web workers {{CompatUnknown}} {{CompatVersionUnknown}} {{CompatUnknown}} {{CompatGeckoMobile("34.0")}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}} {{CompatVersionUnknown}}
now() en un worker dedicado está ahora separado del contexto principal de now(). {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}} {{CompatGeckoMobile("45.0")}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}} {{CompatUnknown}}

[1] Las versiones de Windows desde Chrome 20 al 33 devuelven performance.now() sólo con precisión de milisegundos.

Vea también