(如图)网站左侧菜单栏,从一级菜单移动到二级菜单的过程中,鼠标移入其他一级菜单仍不消失的问题

forwardNow 2015-07-25 03:34:43

(如图)网站左侧菜单栏,从一级菜单移动到二级菜单的过程中,鼠标移入其他一级菜单仍不消失的问题

自己也做过很多尝试,虽然大致实现了,但效果不是很好,有着这样或那样的问题,
跪求标准做法~~~~~~~~~~~~~~~

...全文
664 6 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
6 条回复
切换为时间正序
请发表友善的回复…
发表回复
qq_40103143 2019-03-18
  • 打赏
  • 举报
回复
之前在做公司项目时也需要这个效果,先用了自己的方法,通过给li以及他下面的菜单容器div设置鼠标移入移出可以实现,过程中发现了一个更简单的方法,分享一下。 首先确定菜单结构,菜单里的展开内容要包裹在li,然后给li添加hover函数, var timer = 0; $( "li" ).hover( function() { timer = setTimeout( function() { //当触发hover就开始自动在300ms后执行展开菜单代码 }, 300 ); }, function() { clearTimeout( timer );//当在300ms内移出了li,就清空计时器 } ); 亲测可用,有不清楚的地方可以找我
forwardNow 2015-07-26
  • 打赏
  • 举报
回复
引用 1 楼 showbo 的回复:
jd 电脑,办公那个是用div括起,弹出的子菜单是在这个div里面的,增加div :hover伪样式后显示出来。

你的结构要改成上面的,而不是主菜单和子菜单不在同一个容器下。不同容器你只能用setTimeout延时隐藏,鼠标移动出主菜单后判断是否移动到子菜单上,如果是清楚计时器,否则计时器执行隐藏操作。



我想要的是鼠标向右下移动过程中,子菜单仍旧显示,即使在移动过程中鼠标箭头经过其他的主菜单,如下:

  • 打赏
  • 举报
回复
引用 2 楼 wuqinfei_cs 的回复:
[quote=引用 1 楼 showbo 的回复:]
jd 电脑,办公那个是用div括起,弹出的子菜单是在这个div里面的,增加div :hover伪样式后显示出来。

你的结构要改成上面的,而不是主菜单和子菜单不在同一个容器下。不同容器你只能用setTimeout延时隐藏,鼠标移动出主菜单后判断是否移动到子菜单上,如果是清楚计时器,否则计时器执行隐藏操作。



我想要的是鼠标向右下移动过程中,子菜单仍旧显示,即使在移动过程中鼠标箭头经过其他的主菜单,如下:

[/quote]
没研究过源代码,不过试了下效果,应该是判断了鼠标移动的轨迹了,右下移动有个延时显示子菜单,要是左向下移动子菜单马上显示出来了,有空再看了~
hch126163 2015-07-26
  • 打赏
  • 举报
回复
mouseover 设置子菜单div 显示 mouseout 用setTimeout 延时隐藏子菜单div 鼠标进入 主菜单或者子菜单时,先 清除定时器,再设置子菜单div 显示
forwardNow 2015-07-26
  • 打赏
  • 举报
回复
看上面这张 gif 的图,看鼠标的移动轨迹的两个阶段: 1. 垂直向下移动; 2. 往右下方移动(前往子菜单)。 第一个阶段,移动到哪个主菜单就hover哪个子菜单,以及显示其子菜单; 第二个阶段,从主菜单移向子菜单的过程,鼠标箭头经过了其他的主菜单, 【但他们(其他的主菜单)没有hover以及显示其子菜单】这个才是重点,这个才是我想弄明白的地方。 我把京东的左侧菜单栏给扣出来了(http://forwardnow.github.io/menu.html), 鼠标箭头移动到哪个主菜单上就显示哪个主菜单下的子菜单。 至于鼠标轨迹往右(右上或右下)时,如何判断是向右移动,这是个问题, 我的做法是: 给菜单栏注册 mousemove 事件, 初值坐标为 刚进入时的坐标; 移动过程中,取间隔的两个点的X坐标进行比较, 如果后一个点X值大于前一个点的X值,则判定为向右(右上或右下)。 但这种做法有很大的问题,一直难以解决。
  • 打赏
  • 举报
回复
jd 电脑,办公那个是用div括起,弹出的子菜单是在这个div里面的,增加div :hover伪样式后显示出来。 你的结构要改成上面的,而不是主菜单和子菜单不在同一个容器下。不同容器你只能用setTimeout延时隐藏,鼠标移动出主菜单后判断是否移动到子菜单上,如果是清楚计时器,否则计时器执行隐藏操作。
Visual Studio Code 是由微软开发的一款免费、开源、跨平台的现代化轻量级代码编辑器,自发布以来迅速成为全球开发者最受欢迎的工具之一。它结合了编辑器的轻便性和集成开发环境(IDE)的强大功能,支持多种编程语言和开发场景,核心特点: 1. 跨平台支持 可在 Windows、macOS 和 Linux 上运行,保持一致的用户体验。 2. 轻量级与高性能 启动速度快,占用资源少,适合处理大型项目或低配置设备。 3. 智能代码补全 内置 IntelliSense(智能感知),提供代码提示、参数信息、快速修复等功能,支持 JavaScript、TypeScript、Python、C++ 等主流语言。 4. 内置终端 直接在编辑器内打开集成终端(支持 PowerShell、CMD、Bash 等),方便执行命令行操作。 5. 调试工具 内置调试器,支持断点、变量监视、调用堆栈查看等,无需离开编辑器即可调试代码。 6. Git 集成 直接通过侧边栏管理 Git 仓库,支持提交、分支切换、冲突解决等操作。 7. 丰富的扩展生态系统 通过 Extensions Marketplace 可安装数千款插件,扩展功能包括: 语言支持:如 Java、Go、Rust 等。 主题与图标:自定义界面风格。 工具集成:如 Docker、Kubernetes、数据库连接等。 效率工具:如 REST Client、Live Server 等。 8. 自定义与主题 支持修改键盘快捷键、界面主题、文件图标等,打造个性化开发环境。 9. 多光标编辑 按住 Alt(Windows/Linux)或 Option(macOS)点击可添加多个光标,同时编辑多处代码。 10. 远程开发支持 通过 Remote - SSH、Remote - Containers 等扩展,可直接连接远程服务器或开发容器,实现无缝协作。

87,997

社区成员

发帖
与我相关
我的任务
社区描述
Web 开发 JavaScript
社区管理员
  • JavaScript
  • 无·法
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧