A collection of useful React hooks.
npm install @lcooper/hooks
or
yarn add @lcooper/hooks
Hook | Description |
---|---|
useLatest |
Hook that stores the most recent value in a ref |
usePrevious |
Hook that returns a value from the previous render |
useMergedRef |
Hook that merges two refs into a single callback ref |
useObservedSize |
Hook to track an element's size using the Resize Observer API |
Hook that stores the most recent value in a ref, updating it at each invocation.
value
- value to store
Returns: RefObject
import { useEffect } from 'react';
import { useLatest } from '@lcooper/hooks';
function useExample(arg) {
const latest = useLatest(arg);
useEffect(() => {
// fetch something that takes a while...
fetchSomething().then(() => {
// use the latest value of arg
console.log(latest.current);
});
}, [latest]);
}
Hook that returns a value from the previous render.
value
- current valueinitialValue
- initial value (optional)
Returns: previous value
import { useState } from 'react';
import { usePrevious } from '@lcooper/hooks';
function useCounter(initialCount) {
const [count, setCount] = useState(initialCount),
prevCount = usePrevious(count);
return [count, prevCount, setCount];
}
Hook that merges two refs into a single memoized callback ref.
refA
- FirstRefObject
orRefCallback
to mergerefB
- SecondRefObject
orRefCallback
to merge
Returns: RefCallback
import { useRef, forwardRef } from 'react';
import { useMergedRef } from '@lcooper/hooks';
const Button = forwardRef(({ children, ...props }, ref) => {
const innerRef = useRef(),
mergedRef = useMergedRef(ref, innnerRef);
return <button ref={mergedRef} {...props}>{children}</button>;
});
Hook to track an element's size using the Resize Observer API. Returns a callback ref that must be attached to the element you wish to measure.
Returns [ref: RefCallback, size: { width: number, height: number }]
import { useObservedSize } from '@lcooper/hooks';
function Square() {
const [ref, { width, height }] = useObservedSize();
return (
<div ref={ref} className='square'>
Square size is {width} x {height}
</div>
);
}