React side-effect hook that locks scrolling on the body element. Useful for modal and other overlay components.
import {useLockBodyScroll, useToggle} from 'react-use';
const Demo = () => {
const [locked, toggleLocked] = useToggle(false)
useLockBodyScroll(locked);
return (
<div>
<button onClick={() => toggleLocked()}>
{locked ? 'Unlock' : 'Lock'}
</button>
</div>
);
};
useToggle(enabled?: boolean = true);
enabled
β Hook will lock scrolling on the body element iftrue
, defaults totrue