【问题标题】:CSS + jQuery toggle menuCSS + jQuery 切换菜单
【发布时间】:2012-12-17 09:51:03
【问题描述】:

我正在使用 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

【问题讨论】:

  • 我实际上在菜单上方有一个标题,菜单将滑下,但这不包括在小提琴中,只是在实际页面上。但这应该会给你一个想法。
  • 我已经更新了小提琴以包含标题。

标签: javascript jquery html css menu


【解决方案1】:

你应该委托你的事件,比如

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

DEMO

【讨论】:

  • 我想知道他们是否会改变现场,因为这没有意义,尽管 .on() 的新选择器似乎毫无意义,除非它有速度改进。
【解决方案2】:

使用 .live() 代替 .click()

例子:

$("#tfc-new-nav .hide-menu.menu-hidden").live("click", function() {
    // Do stuff here
}

这考虑了 DOM 的更新操作,经过测试和工作

【讨论】:

  • @ModernDesigner 它是 - .live() - 从 jQuery 1.7 开始,.live() 方法已被弃用。使用 .on() 附加事件处理程序。旧版本 jQuery 的用户应该使用 .delegate() 而不是 .live()。
  • 嗯。这很奇怪,因为我正在使用最新版本的 jQuery(在我的网站上,而不是小提琴上)使用 http://code.jquery.com/jquery.min.js
  • 某些方法被标记为已弃用并不意味着它不起作用。这意味着您应该停止使用它,因为它不会更新,并且会在即将发布的版本中删除。
  • 哦,谢谢理解。就像我说的,我对 jQuery 还是有点陌生​​。所以我所做的是使用.on() 而不是.click(),对于未来的读者,我会看看我是否仍然可以编辑答案。谢谢! :-)
【解决方案3】:

您应该能够调用$.slideToggle() 来处理此问题并缩小您的代码。

这里是手册条目的链接:http://api.jquery.com/slideToggle/

当动画完成时,这将动画并设置display:none

【讨论】:

  • 不,$.slideToggle() 不起作用,因为菜单在标题下滑动,但底部仍然可见,这样用户仍然可以单击向下箭头再次显示菜单。我没有在 jsFiddle 中包含标题(认为没有必要)。
猜你喜欢
  • 1970-01-01
  • 2011-06-24
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
相关资源
最近更新 更多