在使用移动设备或在 Chrome 设备工具栏中查看页面时,我在尝试点击 HeadlessUI 弹出菜单时遇到问题。它似乎在常规桌面浏览器模式下工作正常。我花了几个小时在代码沙箱中测试并将代码提炼成最简单的形式,可以在此处查看和演示:
https://codesandbox.io/s/react-tailwind-rive-animation-tap-issue-bxlt95?file=/src/App.js
这是代码的相关部分:
<Popover className="z-5 relative"> {({ open }) => ( <> <div className="relative z-10"> <Popover.Button aria-label="Main menu" className="text-stone-500 focus:outline-none" > <div className="w-12 h-12"> <Bars3Icon /> </div> </Popover.Button> </div> <Transition as={Fragment} enter="transition ease-out duration-200" enterFrom="opacity-0 -translate-y-1" enterTo="opacity-100 translate-y-0" leave="transition ease-in duration-150" leaveFrom="opacity-100 translate-y-0" leaveTo="opacity-0 -translate-y-1" > <Popover.Panel className="absolute right-0 z-10 mt-2 w-[250px] transform drop-shadow-2xl md:w-[600px] bg-white"> Popup Menu </Popover.Panel> </Transition> </> )} </Popover>
我试图找出是什么导致菜单在点击时无法像浏览器中通常那样弹出。预先感谢您的帮助。
之前有人在另一个论坛回答了我的问题。问题是我的 div 捕获了点击,但没有将其传递给动画。通过将
style={{ pointerEvents: "none" }}
添加到菜单图标周围的 div,它再次开始工作。