как сделать подменю с помощью css?

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

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

Пожалуйста, смотрите изображение выше, я хочу нажать вкладку «перчатки» и «ботинки» слева от «бла 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;
}

person inkplay_    schedule 03.01.2013    source источник
comment
Вы можете добавить его на jsfiddle.net?   -  person iKamy    schedule 03.01.2013


Ответы (2)


Возможно, вы захотите изменить float: left; на float: right:

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

}
person Paul Gleeson    schedule 03.01.2013

Вам не нужны все эти вложенные теги и четкие исправления. Посмотрите на этот codepen.
Всякий раз, когда у вас есть плавающие элементы, используйте overflow: hidden для их родителя. Это делает родительский элемент соответствующим его дочернему контенту.

person Angel Yan    schedule 03.01.2013