PerformanceNavigationTiming

Experimental: This is an experimental technology
Check the Browser compatibility table carefully before using this in production.

The PerformanceNavigationTiming interface provides methods and properties to store and retrieve metrics regarding the browser's document navigation events. For example, this interface can be used to determine how much time it takes to load or unload a document.

Properties

This interface extends the following PerformanceEntry properties for navigation performance entry types by qualifying and constraining them as follows:

PerformanceEntry.entryType Read only

Returns "navigation".

PerformanceEntry.name Read only

Returns the document's address.

PerformanceEntry.startTime Read only

Returns a DOMHighResTimeStamp with a value of "0".

PerformanceEntry.duration Read only

Returns a timestamp that is the difference between the PerformanceNavigationTiming.loadEventEnd and PerformanceEntry.startTime properties.

This interface also extends following PerformanceResourceTiming properties for navigation performance entry types by qualifying and constraining them as follows:

PerformanceResourceTiming.initiatorTypeRead only

Returns "navigation".

The interface also supports the following properties:

PerformanceNavigationTiming.domComplete Read only

A DOMHighResTimeStamp representing a time value equal to the time immediately before the browser sets the current document readiness of the current document to complete.

PerformanceNavigationTiming.domContentLoadedEventEnd Read only

A DOMHighResTimeStamp representing the time value equal to the time immediately after the current document's DOMContentLoaded event completes.

PerformanceNavigationTiming.domContentLoadedEventStart Read only

A DOMHighResTimeStamp representing the time value equal to the time immediately before the user agent fires the DOMContentLoaded event at the current document.

PerformanceNavigationTiming.domInteractive Read only

A DOMHighResTimeStamp representing a timestamp representing the time value equal to the time immediately before the user agent sets the current document readiness of the current document to interactive.

PerformanceNavigationTiming.loadEventEnd Read only

A DOMHighResTimeStamp representing the time when the load event of the current document is completed.

PerformanceNavigationTiming.loadEventStart Read only

A DOMHighResTimeStamp representing the time value equal to the time immediately before the load event of the current document is fired.

PerformanceNavigationTiming.redirectCount Read only

A number representing the number of redirects since the last non-redirect navigation under the current browsing context.

If there was no redirect, or if the redirect was from another origin, and that origin does not permit it's timing information to be exposed to the current origin then the value will be 0.

PerformanceNavigationTiming.requestStart Read only

A DOMHighResTimeStamp representing the time immediately before the user agent starts requesting the resource from the server, or from relevant application caches or from local resources.

PerformanceNavigationTiming.responseStart Read only

A DOMHighResTimeStamp representing the time immediately after the user agent's HTTP parser receives the first byte of the response from relevant application caches, or from local resources or from the server.

PerformanceNavigationTiming.type Read only

A string representing the navigation type. Must be: "navigate", "reload", "back_forward" or "prerender".

PerformanceNavigationTiming.unloadEventEnd Read only

A DOMHighResTimeStamp representing the time value equal to the time immediately after the user agent finishes the unload event of the previous document.

PerformanceNavigationTiming.unloadEventStart Read only

A DOMHighResTimeStamp representing the time value equal to the time immediately before the user agent starts the unload event of the previous document.

Methods

PerformanceNavigationTiming.toJSON()

Returns a DOMString that is the JSON representation of the PerformanceNavigationTiming object.

Specifications

Browser compatibility

Desktop Mobile
Chrome Edge Firefox Internet Explorer Opera Safari WebView Android Chrome Android Firefox for Android Opera Android Safari on IOS Samsung Internet
PerformanceNavigationTiming
57
12
58
You can disable this feature using the dom.enable_performance_navigation_timing preference (see bug 1403926).
No
44
No
57
57
58
You can disable this feature using the dom.enable_performance_navigation_timing preference (see bug 1403926).
43
No
7.0
domComplete
57
12
58
No
44
No
57
57
58
43
No
7.0
domContentLoadedEventEnd
57
12
58
No
44
No
57
57
58
43
No
7.0
domContentLoadedEventStart
57
12
58
No
44
No
57
57
58
43
No
7.0
domInteractive
57
12
58
No
44
No
57
57
58
43
No
7.0
loadEventEnd
57
12
58
No
44
No
57
57
58
43
No
7.0
loadEventStart
57
12
58
No
44
No
57
57
58
43
No
7.0
redirectCount
57
12
58
No
44
No
57
57
58
43
No
7.0
toJSON
57
16
58
No
44
No
57
57
58
43
No
7.0
type
57
12
58
No
44
No
57
57
58
43
No
7.0
unloadEventEnd
57
12
58
No
44
No
57
57
58
43
No
7.0
unloadEventStart
57
12
58
No
44
No
57
57
58
43
No
7.0

See also

© 2005–2021 MDN contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/API/PerformanceNavigationTiming