jquery - 事件/非事件 Jquery 导航菜单

标签 jquery

我不熟悉 javascript,所以如果有人可以帮助我,我将非常感激。

我有一个像这样的简单列表:

<ul>
<li id="nav1">Menu 1</li>
<li id="nav2">Menu 2</li>
<li id="nav3">Menu 3</li>
</ul>

当用户单击菜单元素时,我想添加一个类“menu_active”。

我可以使用以下代码达到此结果:

<script type="text/javascript">
jQuery(document).ready(function() {
jQuery("#nav1").toggle(function () {jQuery(this).addClass("menu_active");},function () {jQuery(this).removeClass("menu_active");});
jQuery("#nav2").toggle(function () {jQuery(this).addClass("menu_active");},function () {jQuery(this).removeClass("menu_active");});
jQuery("#nav3").toggle(function () {jQuery(this).addClass("menu_active");},function () {jQuery(this).removeClass("menu_active");});
});
</script>

该脚本有效,但如果您单击#nav1,然后单击#nav2,然后单击#nav3,所有三个项目都将具有“menu_active”类。

是否有一种简单的方法可以仅突出显示单个菜单元素?

最佳答案

我认为这应该有效:

$(function(){
    var menus = $("#nav1, #nav2, #nav3");
    menus.click(function(){
        menus.not(this).removeClass("menu_active");
        $(this).toggleClass("menu_active");
    });
});

这是一个example .

关于jquery - 事件/非事件 Jquery 导航菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8031240/

相关文章:

jquery - 如何在更改其内容后使用 Jquery UI 调整 div 的大小?

javascript - 使用动态创建的内容将参数传递给 JS 函数

jquery - 如何在 json 中的事件标题中添加换行符

javascript - jQuery 脚本在 jsFiddle 上运行但不在本地运行

javascript - jQuery - 调用 div 类而不是 div id

javascript - 动态 float 气泡..使用Jquery

javascript - 如何使单击链接时边框的颜色发生变化?

javascript - 使用 for 循环切换 div

java - 使用数组或列表在 JSP 中自动完成文本框

javascript - 汉堡包菜单中断收缩标题(反之亦然)