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

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

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

8 ответов

24 просмотра

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

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

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

Господа, а что сейчас вообще с рынком труда на делфи происходит? Какова ситуация?
Rꙮman Yankꙮvsky
29
А вообще, что может смущать в самой Julia - бы сказал, что нет единого стандартного подхода по многим моментам, поэтому многое выглядит как "хаки" и произвол. Короче говоря, с...
Viktor G.
2
30500 за редактор? )
Владимир
47
а через ESC-код ?
Alexey Kulakov
29
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
14
Добрый день! Скажите пожалуйста, а какие программы вы бы рекомендовали написать для того, чтобы научиться управлять памятью? Можно написать динамический массив, можно связный ...
Филипп
7
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Ребят в СИ можно реализовать ООП?
Николай
33
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта