PerformanceElementTiming
The PerformanceElementTiming
interface of the Element Timing API reports timing information on a specific element identified by the page author. For example it could report timing information about the main image in an article.
Properties
-
PerformanceElementTiming.element
Read only -
An
Element
representing the element we are returning information about. -
PerformanceElementTiming.id
Read only -
PerformanceElementTiming.identifier
Read only -
A
DOMString
which is the value of theelementtiming
attribute on the element. -
PerformanceElementTiming.intersectionRect
Read only -
A
DOMRectReadOnly
which is the rectangle of the element within the viewport. -
PerformanceElementTiming.loadTime
Read only -
A
DOMHighResTimeStamp
with the loadTime of the element. -
PerformanceElementTiming.naturalHeight
Read only -
An unsigned 32-bit integer (unsigned long) which is the intrinsic height of the image if this is applied to an image, 0 for text.
-
PerformanceElementTiming.naturalWidth
Read only -
An unsigned 32-bit integer (unsigned long) which is the intrinsic width of the image if this is applied to an image, 0 for text.
-
PerformanceElementTiming.renderTime
Read only -
A
DOMHighResTimeStamp
with the renderTime of the element. -
PerformanceElementTiming.url
Read only -
A
DOMString
which is the initial URL of the resources request for images, 0 for text.
Methods
PerformanceElementTiming.toJSON()
-
Generates a JSON description of the object.
Examples
In this example we have two elements which are being observed. We use the PerformanceObserver
interface to create a list of performance measurement events. In our case observing the PerformanceEntry.entrytype
element
in order to use the PerformanceElementTiming
interface.
Two entries will be output to the console. The first containing details of the image, the second with details of the text node.
<img src="image.jpg" elementtiming="big-image"> <p elementtiming="text" id="text-id">text here</p>
const observer = new PerformanceObserver((list) => { let entries = list.getEntries().forEach(function (entry) { console.log(entry); }); }); observer.observe({ entryTypes: ["element"] });
Specifications
Specification |
---|
Element Timing API # sec-performance-element-timing |
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 | |
PerformanceElementTiming |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
element |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
id |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
identifier |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
intersectionRect |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
loadTime |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
naturalHeight |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
naturalWidth |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
renderTime |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
toJSON |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
url |
77 |
79 |
No |
No |
64 |
No |
77 |
77 |
No |
55 |
No |
12.0 |
© 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/PerformanceElementTiming