如何用css创建子子菜单?

时间:2013-01-03 02:52:49

标签: html css drop-down-menu submenu

http://i.imgur.com/DbMCI.jpg

http://i.imgur.com/i9r6N.jpg

请看上面的图片,我想做的是将“手套”和“靴子”标签推到“blah UGG”左侧

我尝试将子菜单设置为相对位置,将子子菜单设置为绝对位置,但子子菜单消失,如何将子子菜单推到子菜单的左侧?

以下是我的HTML:

<div id="nav-bar" class="cf">
                <nav class="cf">
                    <ul class="topmenu">
                        <li class="hometop"><a href="#"class="hometop">Home</a></li>
                        <li ><a href="#" >Catagory</a>
                            <ul class="submenu">
                                <li><a href="#">Blah Blah</a></li>
                                <li><a href="#">Blah UGGdfddfdf</a>
                                    <ul>
                                        <li>Boots</li>
                                        <li>Gloves</li>
                                    </ul>
                                </li>
                            </ul>
                        </li>
                        <li ><a href="#">About</a></li>
                        <li ><a href="#">How To Order</a></li>
                    </ul>
                </nav>

            </div>

这是我的css:

.cf ul li{
float:left;
margin: 0;
padding: 0;
list-style:none;
font-family:"open sans", sans-serif;

}

.cf li a {
display:block;
padding:0 1em;
line-height: 2.5em;
color:#FFFFFF;
}

.cf li a:hover {
background-color:#ffa627;
}


li{
position:relative;
}
ul.submenu {
float:none;
background: #222;
position:absolute;
left:-9000em;
z-index:1;
width:200px;
height:auto;
}

.topmenu li:hover ul{
left:0;
}   

ul.submenu li {
float:none;
font-size: 12px;
position:relative;

}

.submenu li ul li {
float:none; 
color:#FFFFFF;
display:block;
padding:0 1em;
line-height: 2.5em;

}

#nav-bar nav {
background-color: #222;

}

.cf:before,
.cf:after {
content: " "; /* 1 */
display: table; /* 2 */
}

.cf:after {
clear: both;
}

/**
 * For IE 6/7 only
 * Include this rule to trigger hasLayout and contain floats.
 */
.cf {
    *zoom: 1;
}

2 个答案:

答案 0 :(得分:0)

您可以考虑将float: left;更改为float: right

.cf ul li{
float:right;
margin: 0;
padding: 0;
list-style:none;
font-family:"open sans", sans-serif;

}

答案 1 :(得分:0)

您不需要所有嵌套标记和clearfixes。看看这个codepen 无论何时浮动元素,都要在其父级上使用overflow: hidden。这使父母适合其孩子的内容。