Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/FezVrasta/react-resize-aware
⇲👁 A simple React Hook which allows to listen the resize event of any target element when it changes sizes
https://github.com/FezVrasta/react-resize-aware
listen react resize-events sizes
Last synced: 3 months ago
JSON representation
⇲👁 A simple React Hook which allows to listen the resize event of any target element when it changes sizes
- Host: GitHub
- URL: https://github.com/FezVrasta/react-resize-aware
- Owner: FezVrasta
- License: mit
- Created: 2016-05-04T14:53:10.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2024-03-22T12:03:22.000Z (10 months ago)
- Last Synced: 2024-10-16T04:45:45.259Z (3 months ago)
- Topics: listen, react, resize-events, sizes
- Language: JavaScript
- Homepage: https://fezvrasta.github.io/react-resize-aware
- Size: 291 KB
- Stars: 569
- Watchers: 4
- Forks: 36
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
- awesome-ccamel - FezVrasta/react-resize-aware - ⇲👁 A simple React Hook which allows to listen the resize event of any target element when it changes sizes (JavaScript)
README
# react-resize-aware
It does one thing, it does it well: listens to resize events on any HTML element.
`react-resize-aware` is a zero dependency, **~600 bytes** [React Hook](https://reactjs.org/docs/hooks-reference.html) you can use to detect resize events without relying on intervals, loops, DOM manipulation detection or CSS redraws.
**It takes advantage of the `resize` event on the `HTMLObjectElement`, works on any browser I know of, and it's super lightweight.**
In addition, it doesn't directly alters the DOM, everything is handled by React.
> Looking for the 2.0 docs? [Click here](https://github.com/FezVrasta/react-resize-aware/tree/v2.7.2)
## Installation
```
yarn add react-resize-aware
```or with npm:
```
npm install --save react-resize-aware
```## Usage
The API is simple yet powerful, the `useResizeAware` [Hook](https://reactjs.org/docs/hooks-reference.html)
returns a React node you will place inside the measured element, and an object containing its sizes:```jsx
import React from "react";
import useResizeAware from "react-resize-aware";const App = () => {
const [resizeListener, sizes] = useResizeAware();return (
{resizeListener}
Your content here. (div sizes are {sizes?.width} x {sizes?.height})
);
};
```> **Heads up!**: Make sure to assign a `position != initial` to the HTMLElement you want to target (`relative`, `absolute`, or `fixed` will work).
## API
The Hook returns an array with two elements inside:
### `[resizeListener, ...]` (first element)
This is an invisible React node that must be placed as direct-child of the HTMLElement you want to listen the resize events of.
The node is not going to interfer with your layouts, I promise.
### `[..., sizes]` (second element)
This object contains the `width` and `height` properties, it could be `null` if the element is not yet rendered.
## Custom `reporter`
You can customize the properties of the `sizes` object by passing a custom `reporter` function as first argument of `useResizeAware`.
```tsx
const customReporter = (target: ?HTMLIFrameElement) => ({
clientWidth: target != null ? target.clientWidth : 0,
});const [resizeListener, sizes] = useResizeAware(customReporter);
return (
{resizeListener}
Your content here. (div clientWidth is {sizes.clientWidth})
);
```The above example will report the `clientWidth` rather than the default `offsetWidth` and `offsetHeight`.
## React to size variations
For completeness, below you can find an example to show how to make your code react to size variations using React Hooks:
```jsx
const App = () => {
const [resizeListener, sizes] = useResizeAware();React.useEffect(() => {
console.log("Do something with the new size values");
}, [sizes.width, sizes.height]);return (
{resizeListener}
Your content here.
);
};
```