js 高手帮我修改 再次点击导航 弹出菜单就隐藏

<scripttype="text/javascript"src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jqu... <script type="text/javascript" src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
<script type="text/javascript">
$(function(){$('#nav > dl').click(function(){ //hover是鼠标悬浮,click是鼠标点击。
$(this).addClass('current').siblings('dl').removeClass('current');
$('#nav > dl > dd > ul ').hide();
$(this).find('dd > ul').show();})
})
</script>
展开
 我来答
sunerSy
2013-09-10 · TA获得超过568个赞
知道小有建树答主
回答量:150
采纳率:0%
帮助的人:164万
展开全部

你可以根据class来判断啊!如果当前被点击的dl有current,就隐藏该弹出菜单,代码如下:

<script type="text/javascript">
 $(function(){
     $('#nav > dl').click(function(){ //hover是鼠标悬浮,click是鼠标点击。
         if($(this).hasClass('current')){
             $(this).removeClass('current');
             $('#nav > dl > dd > ul ').hide();
             $(this).find('dd > ul').hide();
         }else{
             $(this).addClass('current').siblings('dl').removeClass('current');
             $('#nav > dl > dd > ul ').hide();
             $(this).find('dd > ul').show();
         }
     });
  });
</script>

这里跟你说下,没写完一句JS语句是要加逗号的,代码规范化,是减少出错的前提!希望对你有所帮助!

随性亻
2013-09-10 · TA获得超过4180个赞
知道小有建树答主
回答量:4622
采纳率:84%
帮助的人:627万
展开全部
//默认给一个值,表示是第一次,还是第二次
var i=0;
$(function(){$('#nav > dl').click(function(){ //hover是鼠标悬浮,click是鼠标点击。
if(i==0){ //第一次点击,展开
$(this).addClass('current').siblings('dl').removeClass('current');
$('#nav > dl > dd > ul ').hide();
$(this).find('dd > ul').show();
i=1;
}else{ //第二次点击就隐藏,代码我没写,不知道你要隐藏哪一部分,你自己改一下就行
$(this).addClass('current').siblings('dl').removeClass('current');
$('#nav > dl > dd > ul ').hide();
$(this).find('dd > ul').show();
i=0;
}
})
追问
麻烦你在帮小弟改下 万分感谢!!!
我改了一下 还是不行啊
追答
$(function(){
$('#nav > dl').click(function(){ //hover是鼠标悬浮,click是鼠标点击。
if(!$(this).hasClass('current')){
$(this).addClass('current').siblings('dl').removeClass('current');
$('#nav > dl > dd > ul ').hide();
$(this).find('dd > ul').show();
$('#nav').find('li').show();
}else{
$(this).removeClass('current');
$(this).children(":last").children().hide();
$('#nav > dl > dd > ul ').hide();
$('#nav').find('li').show();}
}) })

你把这段代码复制粘贴到你那里面就可以用了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

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

类别

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

说明

0/200

提交
取消

辅 助

模 式