@justedoit

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

Доброго дня!

Есть компонент Dropdown.
Необходимо закрывать открытый список по нажатию вне блока.

const Dropdown: FC<DropdownType> = ({
  options,
  onClick,
  title,
}): JSX.Element => {
  const [isOpen, setOpen] = useState<boolean>(false);
  const [activeOption, setActiveOption] = useState<DropdownOptionType>(
    options.find((opt) => opt.default) || options[0],
  );

  const toggling = useCallback(() => setOpen(!isOpen), [isOpen]);

  useEffect(() => {
    const { slug } = activeOption;
    onClick(slug);
  }, [onClick, activeOption]);

  const onOptionClicked = useCallback(
    (option: DropdownOptionType) => {
      setActiveOption(option);
      toggling();
    },
    [toggling],
  );

  return (
    <div className={cn('dropdown')}>
      {title && <p className={cn('title')}>{title}</p>}
      <DropdownToggle
        isOpen={isOpen}
        onClick={toggling}
        option={activeOption}
      />
      {isOpen && (
        <DropdownList
          activeOption={activeOption}
          onOptionClicked={onOptionClicked}
          options={options}
        />
      )}
    </div>
  );
};


Как лучше это сделать?
  • Вопрос задан
  • 488 просмотров
Решения вопроса 1
@ParaBellum577
Вот подобное решение

Либо что-то в таком духе
handleClickOutside(event) {
        if (myRef && !myRef.current.contains(event.target)) {
            alert('You clicked outside of me!');
        }
    }
Ответ написан
Пригласить эксперта
Ответы на вопрос 1
cleverocheck
@cleverocheck
Full-stack web developer
Не стоить писать велосипед, уже все придумали за тебя. Вот неплохой инструмент для данного отслеживания от Material UI
Ответ написан
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
22 нояб. 2024, в 00:55
500 руб./за проект
21 нояб. 2024, в 23:30
300000 руб./за проект
21 нояб. 2024, в 22:21
3000 руб./в час