ResizeObserverEntry: target property
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2020.
The target
read-only property of the
ResizeObserverEntry
interface returns a reference to the
Element
or SVGElement
that is being observed.
Value
An Element
or SVGElement
representing the element being
observed.
Examples
The following snippet is taken from the resize-observer-border-radius.html
(see source) example. This example includes a green box, sized as a percentage of the
viewport size. When the viewport size is changed, the box's rounded corners change in
proportion to the size of the box. We could just implement this using
border-radius
with a percentage, but that quickly leads to ugly-looking
elliptical corners; this solution gives you nice square corners that scale with the box
size.
To grab a reference to the observed element so we can update its
border-radius
value after each change, we make use of the
target
property of each entry —
entry.target.style.borderRadius
.
const resizeObserver = new ResizeObserver((entries) => {
for (const entry of entries) {
if (entry.contentBoxSize) {
entry.target.style.borderRadius = `${Math.min(
100,
entry.contentBoxSize.inlineSize / 10 +
entry.contentBoxSize.blockSize / 10,
)}px`;
} else {
entry.target.style.borderRadius = `${Math.min(
100,
entry.contentRect.width / 10 + entry.contentRect.height / 10,
)}px`;
}
}
});
resizeObserver.observe(document.querySelector("div"));
Specifications
Specification |
---|
Resize Observer # dom-resizeobserverentry-target |