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


Как лучше это сделать?
  • Вопрос задан
  • 408 просмотров
Решения вопроса 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
Ответ написан
Ваш ответ на вопрос

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

Войти через центр авторизации
Похожие вопросы