JQuery 鼠标移到一个层上显示另一个层问题

利用JQuery实现当鼠标移到一级菜单上时,当一级菜单有子菜单的时候则下拉显示,现在出现两个问题,第一个问题是:当鼠标移到一级菜单上时,所有的包含有子菜单的层全都显示出来... 利用JQuery实现 当鼠标移到一级菜单上时, 当一级菜单有子菜单的时候 则下拉显示,
现在出现两个问题,
第一个问题是: 当鼠标移到一级菜单上时, 所有的包含有子菜单的层全都显示出来了 求如何解决.
第二个问题是: 当鼠标快速滑过一级菜单,再把鼠标移到其他地方时, 子菜单层不断的显示关闭, 求如何解决.
JQ效果实现代码如下:
jQuery(document).ready(function ($){
$(".subCategory").hide();
$(".menu").hover (
function(){$(".subCategory").slideDown();},
function(){$(".subCategory").fadeOut();}
);
});
HTML结构代码如下:
<div id="navBox">
<ul id="nav">
<li class="menu">一级菜单 没有子分类</li>
<li class="menu">一级菜单 有子分类
<ul class="subCategory">
<li class="subMenu">二级菜单项目</li>
<li class="subMenu">二级菜单项目</li>
<li class="subMenu">二级菜单项目</li>
</ul>
</li>
<li class="menu">一级菜单 没有子分类</li>
<li class="menu">一级菜单 有子分类
<ul class="subCategory">
<li class="subMenu">二级菜单项目</li>
<li class="subMenu">二级菜单项目</li>
<li class="subMenu">二级菜单项目</li>
</ul>
</li>
<li class="menu">一级菜单 没有子分类</li>
</ul>
</div>
CSS部分代码如下:
#nav{list-style:none;}
.menu{float:left; padding:5px; border:1px solid #ccc; background: #eaeaea; margin:0 5px;}

完整代码因字符超限 打包在微云下载:
http://share.weiyun.com/77e2ef23df2452237769c41a441e8e6c
展开
 我来答
阿刚炖蛋
2013-07-08 · TA获得超过3004个赞
知道大有可为答主
回答量:1789
采纳率:92%
帮助的人:999万
展开全部

你好!


  1. 第一个问题解决思路:每个一级菜单设置hover事件没有问题,但是你的代码中显示的二级菜单却成为了全局所有的了,所以需要修改为当前一级菜单下面的$(".subCategory")元素,即 $(一级菜单).find(".subCategory")--->>> 这样才会显示为当前一级菜单下的二级菜单。

  2. 第二个问题解决思路:由于hover事件中的动画效果没有得到有效的终止,所以在函数队列中会按顺序执行它们,使用stop函数能够有效的终止它们,并直接返回最后的执行结果。


详见附件吧~


徐华平521
2013-07-08
知道答主
回答量:2
采纳率:0%
帮助的人:2932
展开全部
第一个问题主要是因为选择器的问题,你的jquery代码选择的是所有的.subCategory,因该选择对应的subCategory。
第二个问题可以用stop([clearQueue], [gotoEnd]) 函数解决
代码如下:
$(function(){
$('#nav li:has(ul)').hover(function(){

//stop([clearQueue], [gotoEnd])
//概述
//停止所有在指定元素上正在运行的动画。
//如果队列中有等待执行的动画(并且clearQueue没有设为true),他们将被马上执行
//参数
//clearQueue (可选)Boolean如果设置成true,则清空队列。可以立即结束动画。
//gotoEnd (可选)Boolean让当前正在执行的动画立即完成,并且重设show和hide的原始样式,调用回调函数等。

$(this).children('ul').stop(true,true).slideDown(400);
},function(){
$(this).children('ul').stop(true,true).slideUp('fast');
});

});
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友b092569
2013-07-09
知道答主
回答量:15
采纳率:0%
帮助的人:2.1万
展开全部
好像很不错
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
镜奥0i8
2013-07-08 · 超过21用户采纳过TA的回答
知道答主
回答量:57
采纳率:0%
帮助的人:28.6万
展开全部
$(".subCategory").hide();

$("#navBox ul li.menu").hover(function () {
var k = $("#navBox ul li.menu").index(this);
// alert(k);
$(this).children("ul").slideDown();

}, function () {
$(this).children("ul").fadeOut();
})
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
lvming6816077
2013-07-08 · TA获得超过364个赞
知道小有建树答主
回答量:139
采纳率:0%
帮助的人:138万
展开全部

修改这段代码

jQuery(document).ready(function ($){	
$(".subCategory").hide();
var flag = true;//标志位用来限制当第一个动画完成执行第二个
$(".down,.menu").hover (
function(){if (flag) {$(this).find(".subCategory").slideDown();flag = false}},
function(){$(this).find(".subCategory").fadeOut(function(){
flag = true;
});}
);
});

 绑定事件的时候要找到当前触发事件的对象才行

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
茶苦亦觉甜
2013-07-08 · TA获得超过114个赞
知道小有建树答主
回答量:444
采纳率:0%
帮助的人:134万
展开全部
这个问题首先要从根本上解决,html的结构要清晰才好做,大部分人初期总是把子菜单和主菜单分开,鼠标进入,移除嵌套关系很复杂。其实最核心的一点,子菜单必须包含在主菜单,鼠标进入的事件写在容器上,这样弄就好了。比如:
<ul>
<li onmouseover="鼠标进入,子ul显示"><a href="#">一级菜单</a>
<ul>
<li>1-1</li>
<li>1-2</li>
</ul>
</li>
</ul>
如果一开始把事件写在 <a href="#">一级菜单</a> 上,就会造成js很麻烦,判断mouseover,mouseout等等。
我上面写的是底层的原理,你自己结合jquery优化。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(5)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式