仅重写响应式菜单到css

时间:2013-08-05 10:30:06

标签: javascript css menu responsive-design

我有菜单:

JSFIDLE

jsfidle


HTML

<a class="toggleMenu" href="#"><img src="img/icon-menu.png" alt=""></a>
<ul class="menu">
    <li class="first activeSelected"><a href="#">Homepage</a></li>
    <li><a href="#">About Us</a></li>
    <li><a href="#">Services</a>        
        <ul class="level1">
            <li class="first"><a href="#">Fitness</a></li>
            <li class="last"><a href="#">Sport and relax</a></li>
        </ul>
    </li>
    <li><a href="#">News</a></li>
    <li class="last"><a href="#">Contact Us</a></li>
</ul>

CSS

/* MENU */

.menu {
    margin: 0; 
    padding: 0;
}

.menu a {
    text-decoration: none;
}

.toggleMenu {
    display:  none;
    padding: 9px 9px 6px 9px;
    margin: 0px 0 0 2px;
    color: #000;
    background: #00a1ba;
    border: 1px #00a1ba solid;
}

.menu {
    list-style: none;
    *zoom: 1;
    z-index: 99;
}
.menu:before,
.menu:after {
    content: " "; 
    display: table; 
}
.menu:after {
    clear: both;
}
.menu ul {
    list-style: none;
    width: 9em;
}
.menu a {
    padding: 10px 15px;
    color: #848484;
}

.menu a:hover {
    background: #0093aa;
}

.active {
    color: #fff;
    background: #0093aa;
}

.menu li {
    position: relative;
}
.menu > li {
    float: left;
    background: #fff;
}

.menu > li:hover {
    background: #0093aa;
}

.menu > li:hover a {
    color: #fff;
}

.menu > li > .parent {
    /*background-image: url("../img/downArrow.png");*/
    background-repeat: no-repeat;
    background-position: right;
}
.menu > li > a {
    display: block;
}
.menu li ul {
    position: absolute;
    left: -9999px;
}
.menu > li.hover > ul {
    left: 0;
}
.menu li li.hover ul {
    left: 100%;
    top: 0;
}

.menu li li a {
    display: block;
    background: #00a1ba;
    color: #fff;
    position: relative;
    z-index: 100;
    border-top: 1px solid #0093aa;
}

.menu li li li a {
    background: #00a1ba;
    color: #fff;
    z-index:200;
    border-top: 1px solid #0093aa;
}

@media screen and (max-width: 640px) {

    .menu {
        position: absolute; 
        right: 0;
        text-align: center;
    }

    .active {
        display: block;
    }
    .menu > li {
        float: none;
        background: #00a1ba;
        border-top: 1px solid #0093aa;
        max-width: 280px; 
        min-width: 200px;
    }

    .menu > li:hover {
        background: #0093aa;
    }

    .menu > li > a {
        color: #fff;
    }
    .menu > li > .parent {
    background-position: 95% 50%;
    }
    .menu li li .parent {
        /*background-image: url("../img/downArrow.png");*/
        background-repeat: no-repeat;
        background-position: 95% 50%;
    }
    .menu ul {
        display: block;
        width: 100%;
    }

    .menu li li a:hover {
        background: #0093aa;
    }

    .menu > li.hover > ul , .menu li li.hover ul {
        position: static;
    }

}

JS

var ww = document.body.clientWidth;

$(document).ready(function() {
    $(".menu li a").each(function() {
        if ($(this).next().length > 0) {
            $(this).addClass("parent");
        }
        ;
    })

    $(".toggleMenu").click(function(e) {
        e.preventDefault();
        $(this).toggleClass("active");
        $(".menu").toggle();
    });
    adjustMenu();
})

$(window).bind('resize orientationchange', function() {
    ww = document.body.clientWidth;
    adjustMenu();
});

var adjustMenu = function() {
    if (ww < 640) {
        $(".toggleMenu").css("display", "inline-block");
        if (!$(".toggleMenu").hasClass("active")) {
            $(".menu").hide();
        } else {
            $(".menu").show();
        }
        $(".menu li").unbind('mouseenter mouseleave');
        $(".menu li a.parent").unbind('click').bind('click', function(e) {
            // must be attached to anchor element to prevent bubbling
            e.preventDefault();
            $(this).parent("li").toggleClass("hover");
        });
    }
    else if (ww >= 640) {
        $(".toggleMenu").css("display", "none");
        $(".menu").show();
        $(".menu li").removeClass("hover");
        $(".menu li a").unbind('click');
        $(".menu li").unbind('mouseenter mouseleave').bind('mouseenter mouseleave', function() {
            // must be attached to li so that mouseleave is not triggered when hover over submenu
            $(this).toggleClass('hover');
        });
    }
}

问:

如何悬停 toogle不用JS

3 个答案:

答案 0 :(得分:0)

对于多级别,您可以尝试这一个级别 http://jsfiddle.net/cancerian73/gAMVM/

body {
background: #ccc;
font-family: helvetica, arial, serif;
font-size: 13px;
text-transform: uppercase;
text-align: center;
}

答案 1 :(得分:0)

这是一个仅限CSS的示例,向您展示您正在谈论的HOVER效果

FIDDLE

将鼠标悬停在“程序”链接上并进行检查。 此效果可应用于HTML

中的任何元素

CSS语法如下

Element_name:Hover{
       // CSS code
}

示例:

img{
opacity:1;
}
img:hover{
opacity:0;
}

以上示例将在悬停时使img透明。

答案 2 :(得分:0)

  

如何在没有JS的情况下进行悬停和托管?

你可以在CSS选择器中使用:hover pseudoclass

要切换,您只需将display:none;应用于元素即可。

使用纯CSS无法做的是响应click事件。你需要JS。