Skip to content
This repository has been archived by the owner on Nov 11, 2024. It is now read-only.
/ use-element-size Public archive

Track the size of a react-dom element in 540 bytes (without ResizeObserver)

License

Notifications You must be signed in to change notification settings

alloc/use-element-size

Repository files navigation

use-element-size

Track the size of a react-dom element (without ResizeObserver).

Only 540 bytes min+gzip!

Usage

import React from 'react'
import { useElementSize } from 'use-element-size'

const Example = () => {
  const ref = useElementSize((size, prevSize, elem) => {
    console.log({ size, prevSize, elem })
  })
  return (
    <div
      ref={ref}
      style={{
        position: 'relative',
        width: '50%',
        height: '50%',
      }}
    />
  )
}

Quirks

  • ⚠️ Be sure the tracked element never has position: static.

  • The size parameter is null when the tracked element is unmounted.

  • The prevSize parameter is null when the tracked element was just mounted.

  • Tracking stops when useElementSize is passed false/null/undefined instead of a function.

  • The callback waits until the next requestAnimationFrame tick before running.

  • The Size and SizeCallback types are exported for your convenience.

Demo

https://codesandbox.io/s/use-element-size-demo-dszk1?file=/src/index.tsx

About

Track the size of a react-dom element in 540 bytes (without ResizeObserver)

Topics

Resources

License

Stars

Watchers

Forks