169 похожих чатов

Имеется навбар, в котором при клике на элемент показывается раскрывающийся

список. Как сделать так, чтобы при клике в любое место на странице список закрывался? document.body.addEventListener??

8 ответов

6 просмотров

react

Eduard-Balichev Автор вопроса
倫太郎 岡部
react

Как в реакте отловить клик по рандомному месту в теле документа?

для чего?

Eduard-Balichev Автор вопроса
倫太郎 岡部
для чего?

Ты кликаешь по элементу навбара => раскрывается список. При раскрытом списке, если кликнуть ао рандомному месту страницы список должен закрыться

Eduard-Balichev Автор вопроса
倫太郎 岡部
ну это просто click outside

Это какая-то всратая библиотека? Мне кажется неправильным на каждое действие новую библиотеку подключать. Решение с document.body.addEventListener кажется более разумным

Eduard Balichev
Это какая-то всратая библиотека? Мне кажется непра...

конечно это библиотека, ведь для всего в интернете есть биболитека

Eduard Balichev
Это какая-то всратая библиотека? Мне кажется непра...

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; }

Похожие вопросы

Обсуждают сегодня

я не магистр хаскеля, но разве не может лейзи тип конвертнуться в не-лейзи запросив вычисление содержимого прям при инициализации?
deadgnom32 λ madao
89
читать файл максимально быстро? странный вопрос))
zamtmn
53
How to create an OS in C? what to study?
Linus
18
Всем доброго вечера! Хочу поделиться своим злоключением с человеком, который, как оказалось сюда тоже скидывал свое резюме. Жаль, что я вашу группу не нашел раньше… человек ки...
Роман Ахмедзянов
4
тоесть, указав return eax, сгенерируется никому ненужная инструкция mov eax,eax ?
Aiwan \ (•◡•) / _bot
24
Компания Elif ищет менеджера проектов, который будет заниматься поиском и ведением новых проектов. Прежде чем приступить к работе, вам нужно пройти наш недельный курс, где вы ...
Elif
5
Привет, кто может сделать юзербота с апи? Задачи: - создавать группы - создавать каналы - задавать для созданных каналов аватарку или эмоджи, имя группы - добавлять в группы...
Lencore
11
Вопрос вроде правильно, но что надо сделать, чтоб текст был виден нормально ? ghci> TE.decodeUtf8 $ TE.encodeUtf8 "test - проба" "test - \1087\1088\1086\1073\1072"
Fedor
7
а зачем этот вопрос для удаления из чата?
Mёdkinson Medvezhkin
63
@HemulGM Параметры у AddStream поменялись? Несостыковка какая-то
Катерина Свиридова
12
Карта сайта