2.0.2 • Published 1 year ago
@react-hook/resize-observer v2.0.2
A React hook that fires a callback whenever ResizeObserver detects a change to its size.
Features
- Uses a single
ResizeObserverfor tracking all elements used by the hooks. This approach is astoundingly more performant than using aResizeObserverper element which most hook implementations do. - Automatically unobserves the target element when the hook unmounts.
- You don't have to wrap your callback in
useCallback()because any mutations are handled by the hook.
Quick Start
Check out an example on CodeSandbox
import * as React from 'react'
import useResizeObserver from '@react-hook/resize-observer'
const useSize = (target) => {
const [size, setSize] = React.useState()
React.useLayoutEffect(() => {
setSize(target.current.getBoundingClientRect())
}, [target])
// Where the magic happens
useResizeObserver(target, (entry) => setSize(entry.contentRect))
return size
}
const App = () => {
const target = React.useRef(null)
const size = useSize(target)
return (
<pre ref={target}>
{JSON.stringify({width: size.width, height: size.height}, null, 2)}
</pre>
)
}API
useResizeObserver(target, callback, options)
function useResizeObserver<T extends Element>(
target: React.RefObject<T> | React.ForwardedRef<T> | T | null,
callback: UseResizeObserverCallback,
options?: UseResizeObserverOptions
): ResizeObserver| Argument | Type | Required? | Description |
|---|---|---|---|
| target | React.RefObject | T | null | Yes | A React ref created by useRef() or an HTML element |
| callback | UseResizeObserverCallback | Yes | Invoked with a single ResizeObserverEntry any time the target resizes |
| options | UseResizeObserverOptions | No | Options for the ResizeObserver instance. |
Types
UseResizeObserverCallback
export type UseResizeObserverCallback = (
entry: ResizeObserverEntry,
observer: ResizeObserver
) => anyUseResizeObserverOptions
export type UseResizeObserverOptions = {
polyfill?: any
}polyfill
A ResizeObserver polyfill implementation such as @juggle/resize-observer (this was the default in V1.x).
import useResizeObserver from '@react-hook/resize-observer'
import {ResizeObserver} from '@juggle/resize-observer'
useResizeObserver(..., ..., { polyfill: ResizeObserver })LICENSE
MIT
2.0.2
1 year ago
2.0.1
1 year ago
2.0.0
1 year ago
1.2.6
3 years ago
1.2.5
4 years ago
1.2.4
4 years ago
1.2.3
4 years ago
1.2.2
4 years ago
1.2.1
4 years ago
1.2.0
5 years ago
1.1.2
5 years ago
1.1.1
5 years ago
1.1.0
5 years ago
1.0.4
5 years ago
1.0.3
5 years ago
1.0.2
5 years ago
1.0.1
5 years ago
1.0.0
5 years ago
0.0.2
5 years ago
0.0.1
5 years ago