A state container which provides an interface for retrieving the bounding
client rect of a referenced element. The bounding client rect will update
each time the window resizes - a behavior which can be turned off by setting
the prop recalcOnWindowResize
to false
. It doesn't provide values for x
and
y
, as IE, Edge and Safari don't have them as part of their DOMRect
.
yarn add @render-props/rect
or npm i @render-props/rect
import Rect from '@render-props/rect'
function DivWithRect (props) {
return (
<Rect>
({rectRef, recalcRect, top, right, bottom, left, width, height}) => (
<div ref={rectRef}>
<div>
My width: {width}
</div>
<div>
My height: {height}
</div>
<div>
My position: {JSON.stringify({top, right, bottom, left})}
</div>
</div>
)
</Rect>
)
}
recalcOnWindowResize {bool}
: iftrue
, this component will update itself each time a window resize event is detected. Defaults totrue
.withCoords {bool}
: iftrue
, this component will provide its child function with unpacked arguments for its bounding client rect, i.e.{top, right, bottom, left, width, height}
. Iffalse
, it will provide a functiongetRect
instead which will return the same object just mentioned. Defaults totrue
.
rectRef
(element
)- This
ref
must be provided to whatever element you are trying to receive the bounding client rect for. e.g.<div ref={rectRef}>
- This
recalcRect
- remeasures the element bound to
rectRef
- remeasures the element bound to
getRect
- only present if
withCoords
is set tofalse
. Returns the bounding client rect object.
- only present if
Note: these are only provided if withCoords
is true
.
top {number}
: the top coordinate value of theDOMRect
right {number}
: the right coordinate value of theDOMRect
bottom {number}
: the bottom coordinate value of theDOMRect
left {number}
: the left coordinate value of theDOMRect
width {number}
: the width of theDOMRect
height {number}
: the height of theDOMRect