--- title: performance.now() slug: Web/API/Performance/now tags: - API - Referencia - Rendimiento - Web Performance API - metodo translation_of: Web/API/Performance/now ---
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:
performance.now()
en la pestaña que generó el worker. Solía ser igual que t0
del contexto principal, pero fue cambiado.t = performance.now();
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()
.
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 |
{{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.