当没有切换选项时,我的桌面大小为state= false,因为它最初被定义为false.因此,没有显示菜单.我想要这个功能,只有当网站是在手机上打开,而不是在桌面上.

const Navbar = () => {
  const [isMenuOpen, setIsMenuOpen] = useState(false);
  const toggle = () => setIsMenuOpen(!isMenuOpen);
  const ref = useRef();

  useEffect(() => {
    const checkIfClickedOutside = (e) => {
      if (!ref.current?.contains(e.target)) {
        setIsMenuOpen(false);
      }
    };
    document.addEventListener("mousedown", checkIfClickedOutside);
    return () => {
      document.removeEventListener("mousedown", checkIfClickedOutside);
    };

  }, []);

  return (
    <>
      <header>
        <nav>
          <div className="nav">
            <div className="nav-brand">
              <Link to="./" className="text-black">
                Website
              </Link>
            </div>
            <div ref={ref}> // <-- ref to this containing div
              <div className="toggle-icon" onClick={toggle}>
                <i
                  id="toggle-button"
                  className={isMenuOpen ? "fas fa-times" : "fas fa-bars"}
                />
              </div>
              {isMenuOpen && (
                <div className={isMenuOpen ? "nav-menu visible" : "nav-menu"}>
                  ....
                </div>
              )}
            </div>
          </div>
        </nav>
      </header>
    </>
  );
};

Edit morning-leftpad-4mgs2n

推荐答案

创建初始状态值,判断窗口的宽度是否大于移动媒体查询大小.

* Small devices (landscape phones, less than 768px) */
@media only screen and (max-width: 767.98px) {
  /* -------------Bottom Header------------- */
  .....
}

例子:

const isMobile = window.innerWidth <= 767.98;

export default function App() {
  const [isMenuOpen, setIsMenuOpen] = useState(!isMobile);
  const toggle = () => isMobile && setIsMenuOpen(!isMenuOpen);

  const ref = useRef();

  useEffect(() => {
    if (isMobile) {
      const checkIfClickedOutside = (e) => {
        if (!ref.current?.contains(e.target)) {
          setIsMenuOpen(false);
        }
      };
    
      document.addEventListener("mousedown", checkIfClickedOutside);
    
      return () => {
        // Cleanup the event listener
        document.removeEventListener("mousedown", checkIfClickedOutside);
      };
    }
  }, []);

  return ( .... );
}

Edit menus-are-not-showing-on-desktop-display

OFC假设应用程序的视口是静态的.如果需要动态响应,那么使用useEffect钩子向window对象添加onResize事件处理程序.

例子:

useEffect(() => {
  const resizeHandler = () => {
    ... logic to get window size and handle setting the menu state
  };

  window.addEventListener("resize", resizeHandler);

  return () => {
    window.removeEventListener("resize", resizeHandler);
  };
}, []);

Javascript相关问答推荐

如何在NightWatch.js测试中允许浏览器权限?

在分区内迭代分区

jQuery提交按钮重新加载页面,即使在WordPress中使用preventDefault()

配置WebAssembly/Emscripten本地生成问题

在服务器上放置了Create Reaction App Build之后的空白页面

setcallback是什么时候放到macrotask队列上的?

查找最长的子序列-无法重置数组

用于编辑CSS样式的Java脚本

我怎么才能得到Kotlin的密文?

在浏览器中触发插入事件时检索编码值的能力

从Nextjs中的 Select 项收集值,但当单击以处理时,未发生任何情况

Angular 形式,从DOM中删除不会删除指定索引处的内容,但会删除最后一项

为什么可选参数的顺序会导致问题?

在不扭曲纹理的情况下在顶点着色器中旋转UV

在单击按钮时生成多个表单时的处理状态

在ChartJS中使用spanGaps时,是否获取空值的坐标?

Chart.js Hover线条在鼠标离开时不会消失

脚本语法错误只是一个字符串,而不是一个对象?

当达到高度限制时,如何裁剪图像?使用html和css

如何在Java脚本中添加一个可以在另一个面板中垂直调整大小的面板?