ref
and a callback
to handle the 'click'
event.useEffect()
hook to append and clean up the click
event.useRef()
hook to create a ref
for your click component and pass it to the useClickInside
hook.const useClickInside = (ref, callback) => { const handleClick = e => { if (ref.current && ref.current.contains(e.target)) { callback(); } }; React.useEffect(() => { document.addEventListener('click', handleClick); return () => { document.removeEventListener('click', handleClick); }; }); };
const ClickBox = ({ onClickInside }) => { const clickRef = React.useRef(); useClickInside(clickRef, onClickInside); return ( <div className="click-box" ref={clickRef} style={{ border: '2px dashed orangered', height: 200, width: 400, display: 'flex', justifyContent: 'center', alignItems: 'center' }} > <p>Click inside this element</p> </div> ); }; ReactDOM.render( <ClickBox onClickInside={() => alert('click inside')} />, document.getElementById('root') );
Subscribe to get resources directly to your inbox. You won't receive any spam! ✌️