javascript - CSS + jQuery 切换菜单

标签 javascript jquery html css menu

我正在使用 jQuery + CSS3 制作菜单。

菜单右侧有一个向上箭头,单击时菜单会向上滑动,图像会切换为向下箭头。

唯一的问题是,如果您单击向下箭头,它不会向下滑动,即使我提供了一段合法的代码以使其正常工作。

我是 jquery 新手,因此非常感谢任何帮助!

HTML:

<nav id="tfc-new-nav">
    <div class="wrapper">
        <ul>
            <li><a href="index.html">Home</a></li>
            <li><a href="contact.html">Contact</a></li>
            <li><a href="cart.html">Shopping Cart</a></li>
            <li><a href="login.html">My Account</a></li>
        </ul>
    </div>
    <div class="hide-menu menu-active"></div>
</nav>​

CSS:

.wrapper {
    display: block;
    height: 100%;
    width: 1000px;
    position: relative;
    margin: 0 auto;
}

#tfc-new-nav {
    display: block;
    height: 45px;
    width: 100%;
    background: #808E91;
    position: relative;
    top: 50px;
}

#tfc-new-nav ul {
    list-style: none;
}

#tfc-new-nav ul li {
    display: block;
    height: 45px;
    width: 10%;
    float: left;
    text-align: center;
    line-height: 45px;
}

#tfc-new-nav ul li a {
    display: block;
    color: #fff;
    text-decoration: none;
    text-transform: uppercase;
    font-family: 'Felix Titling', serif;
    cursor: pointer;
    -webkit-transition: background .3s ease-in;
    -moz-transition: background .3s ease-in;
    -ms-transition: background .3s ease-in;
    -o-transition: background .3s ease-in;
    transition: background .3s ease-in;
}

#tfc-new-nav ul li a:hover {
    background: #50798D;
}

#tfc-new-nav .hide-menu {
    position: absolute;
    top: 20px;
    right: 10px;
    cursor: pointer;
}

#tfc-new-nav .hide-menu.menu-active {
    display: block;
    background-image: url('http://upload.wikimedia.org/wikipedia/commons/6/61/Black_Up_Arrow.png');
    background-size: 100% 100%;
    height: 7px;
    width: 7px;
}

#tfc-new-nav .hide-menu.menu-hidden {
    display: block;
    background-image: url('http://www.wpclipart.com/signs_symbol/BW/direction_arrows/down_arrow.png');
    background-size: 100% 100%;
    height: 7px;
    width: 7px;
}​

JavaScript:

$(document).ready(function() {

    $("#tfc-new-nav .hide-menu.menu-active").click(function() {

        $("#tfc-new-nav").animate({

            top: "30px"

        });

        $(this).removeClass("menu-active");
        $(this).addClass("menu-hidden");

        $(this).animate({
            top: "35px"
        });

    });

    $("#tfc-new-nav .hide-menu.menu-hidden").click(function() {

        $("#tfc-new-nav").animate({

            top: "95px"

        });

        $(this).removeClass("menu-hidden");
        $(this).addClass("menu-active");

        $(this).animate({
            top: "20px"
        });

    });

});​

LIVE DEMO

最佳答案

您应该委托(delegate)您的事件,例如

$("#tfc-new-nav").on("click", ".menu-hidden", function() {
    ...
});

DEMO

关于javascript - CSS + jQuery 切换菜单,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14132050/

相关文章:

javascript - IE 甚至 Chrome 有时不会用 jquery/javascript 填充时间

jquery - 如何使用 Jquery 替换 DIV 中包含的字符并替换为图像?

javascript - 如何为 <noscript> 标签编写自动化测试?

php - 使用 PHP 和 jQuery 管理主题编辑

javascript - 如何在没有 IDE 的情况下构建和部署三星 SmartTV 应用程序(例如 : on Linux)

html - 带有边框轮廓的圆形边框半径在页面加载时仅显示为正方形?

javascript - 表单发布返回文件时显示 'wait' 光标

javascript - 使用 Javascript/Windows 批处理文件混合将非 ASCII 字符编码为 HTML

javascript - getElementById 从段落中返回未定义

javascript - 无法将 div 动画两次移动到所需位置