docs.rodeo

MDN Web Docs mirror

Performance: timeOrigin property

{{APIRef("Performance API")}} {{AvailableInWorkers}} 

The timeOrigin read-only property of the {{domxref("Performance")}}  interface returns the high resolution timestamp that is used as the baseline for performance-related timestamps.

In Window contexts, this value represents the time when navigation has started. In {{domxref("Worker")}}  and {{domxref("ServiceWorker")}}  contexts, this value represents the time when the worker is run. You can use this property to synchronize the time origins between the contexts (see example below).

[!NOTE] The value of performance.timeOrigin may differ from the value returned by {{jsxref("Date.now()")}}  executed at the time origin, because Date.now() may have been impacted by system and user clock adjustments, clock skew, etc. The timeOrigin property is a monotonic clock which current time never decreases and which isn’t subject to these adjustments.

Value

A high resolution timestamp which considered to be the beginning of the current document’s lifetime. It’s calculated like this:

Examples

Synchronizing time between contexts

To account for the different time origins in window and worker contexts, you can translate the timestamps coming from worker scripts with the help of the timeOrigin property, so the timings synchronize for the entire application.

In worker.js

self.addEventListener("connect", (event) => {
  const port = event.ports[0];

  port.onmessage = function (event) {
    const workerTaskStart = performance.now();
    // doSomeWork()
    const workerTaskEnd = performance.now();
  };

  // Convert worker-relative timestamps to absolute timestamps, then send to the window
  port.postMessage({
    startTime: workerTaskStart + performance.timeOrigin,
    endTime: workerTaskEnd + performance.timeOrigin,
  });
});

In main.js

const worker = new SharedWorker("worker.js");
worker.port.addEventListener("message", (event) => {
  // Convert absolute timestamps into window-relative timestamps
  const workerTaskStart = event.data.startTime - performance.timeOrigin;
  const workerTaskEnd = event.data.endTime - performance.timeOrigin;

  console.log("Worker task start: ", workerTaskStart);
  console.log("Worker task end: ", workerTaskEnd);
});

Specifications

{{Specifications}} 

Browser compatibility

{{Compat}} 

In this article

View on MDN