首页 >web前端 >js教程 >在外部单击或滚动时关闭模式或下拉菜单。

在外部单击或滚动时关闭模式或下拉菜单。

Patricia Arquette
Patricia Arquette原创
2024-12-28 08:45:10730浏览

Closing modals or dropdown on Outside click or scroll.

是否曾经构建过模态框或下拉菜单,并努力弄清楚当用户在其外部单击时如何将其关闭?是的..

这里有一个很酷的 React hook 可以解决这个问题

import { useEffect, useRef } from "react";

const useOutsideClickOrScroll = <T extends HTMLElement>(
  callback: () => void
) => {
  const ref = useRef<T>(null);

  useEffect(() => {
    const handleClickOutside = (event: MouseEvent) => {
      if (ref.current && !ref.current.contains(event.target as Node)) {
        callback();
      }
    };

    const handleScroll = () => {
      callback();
    };

    document.addEventListener("mousedown", handleClickOutside);
    window.addEventListener("scroll", handleScroll, true);

    return () => {
      document.removeEventListener("mousedown", handleClickOutside);
      window.removeEventListener("scroll", handleScroll, true);
    };
  }, [callback]);

  return ref;
};

export default useOutsideClickOrScroll;

此钩子使用 useRef 来定位 DOM 元素,并在外部点击或滚动事件上触发回调,确保使用 useEffect 进行正确的清理。它返回 ref,以便轻松附加到任何 DOM 元素。

这是一个示例用法

import React, { useState } from "react";
import useOutsideClickOrScroll from "./useOutsideClickOrScroll";

const Dropdown = () => {
  const [isOpen, setIsOpen] = useState(false);

  const handleClose = () => {
    setIsOpen(false);
  };

  const ref = useOutsideClickOrScroll<HTMLDivElement>(handleClose);

  return (
    <div>
      <button onClick={() => setIsOpen(!isOpen)}>Toggle Dropdown</button>
      {isOpen && (
        <div ref={ref}>
          <p>Dropdown Content</p>
        </div>
      )}
    </div>
  );
};

export default Dropdown;

以上是在外部单击或滚动时关闭模式或下拉菜单。的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn