список. Как сделать так, чтобы при клике в любое место на странице список закрывался? document.body.addEventListener??
react
Как в реакте отловить клик по рандомному месту в теле документа?
для чего?
Ты кликаешь по элементу навбара => раскрывается список. При раскрытом списке, если кликнуть ао рандомному месту страницы список должен закрыться
ну это просто click outside
Это какая-то всратая библиотека? Мне кажется неправильным на каждое действие новую библиотеку подключать. Решение с document.body.addEventListener кажется более разумным
конечно это библиотека, ведь для всего в интернете есть биболитека
import { useEffect, useRef } from 'react'; const DEFAULT_EVENTS = ['mousedown', 'touchstart']; export function useClickOutside<T extends HTMLElement = any>( handler: () => void, events?: string[] | null, nodes?: HTMLElement[] ) { const ref = useRef<T>(); useEffect(() => { const listener = (event: any) => { if (Array.isArray(nodes)) { const shouldIgnore = event?.target?.hasAttribute('data-ignore-outside-clicks'); const shouldTrigger = nodes.every((node) => !!node && !node.contains(event.target)); shouldTrigger && !shouldIgnore && handler(); } else if (ref.current && !ref.current.contains(event.target)) { handler(); } }; (events || DEFAULT_EVENTS).forEach((fn) => document.addEventListener(fn, listener)); return () => { (events || DEFAULT_EVENTS).forEach((fn) => document.removeEventListener(fn, listener)); }; }, [ref, handler, nodes]); return ref; }
Обсуждают сегодня