我想将列表更改为垂直列表,但在更改了大量的css代码之后,内部列表应该是水平的,并且我无法找到原因。
nav ul ul { display: none;}
nav ul li:hover > ul { display: block; }
nav ul {
background: #efefef;
background: linear-gradient(top, #efefef 0%, #bbbbbb 100%);
background: -moz-linear-gradient(top, #efefef 0%, #bbbbbb 100%);
background: -webkit-linear-gradient(top, #efefef 0%,#bbbbbb 100%);
box-shadow: 0px 0px 9px rgba(0,0,0,0.15);
padding: 0 20px;
border-radius: 10px;
list-style: none;
position: relative;
display:list-item;
}
nav ul:after {
content: ""; clear: both; display: block;
}
nav ul li {
float: left;
}
nav ul li:hover {
background: #4b545f;
background: linear-gradient(top, #4f5964 0%, #5f6975 40%);
background: -moz-linear-gradient(top, #4f5964 0%, #5f6975 40%);
background: -webkit-linear-gradient(top, #4f5964 0%,#5f6975 40%);
}
nav ul li:hover a {
color: #fff;
}
nav ul li a {
display: block; padding: 25px 40px;
color: #757575; text-decoration: none;
}
nav ul ul {
background: #5f6975; border-radius: 0px; padding: 0;
position: absolute; top: 100%;
}
nav ul ul li {
display:list-item;
float: right;
border-top: 1px solid #6b727c;
border-bottom: 1px solid #575f6a;
position: relative;
}
nav ul ul li a {
padding: 15px 40px;
color: #fff;
}
nav ul ul li a:hover {
background: #4b545f;
}
nav ul ul ul {
position: absolute; left: 100%; top:0;
}
这是html标记:
<nav>
<ul>
<li>
<a href="Documents.php">Products</a>
<ul>
<li><a href="Documents.php?cat=Political">Books</a></li>
<li><a href="Documents.php?cat=History">Magazines</a></li>
<li><a href="Documents.php?cat=Culture">MusicCd's</a></li>
</ul>
</li>
<li><a href="html/about.html">ABOUT</a></li>
<li><a href="html/contact.html">CONTACT</a></li>
</ul>
</nav>
答案 0 :(得分:3)
因此,您希望父菜单项垂直定位(相互下降),嵌套子菜单水平定位(相互左移)。
假设它是我们的html标记:
<nav>
<ul>
<li>Parent 1
<ul>
<li>Child 1</li>
<li>Child 2</li>
<li>Child 3</li>
</ul>
</li>
<li>Parent 2
<ul>
<li>Child 4</li>
<li>Child 5</li>
<li>Child 6</li>
</ul>
</li>
</ul>
</nav>
将我们告诉他们的父菜单项定位到clear
他们的left
。所以没有任何元素可以浮动到他们的右边:
nav > ul > li {
clear: left;
}
(另请注意,要仅指定我们使用的>
Child combinator的父菜单项。所以此样式不会影响内部li
s。仅父li
得到那个css属性。)
然后我们隐藏子菜单项,让它们只出现在鼠标上:
nav > ul > li ul {
display: none;
}
nav > ul > li:hover ul {
display: block;
}
最后一件事是告诉子菜单项向左浮动并显示为内联元素。所以这样我们就可以获得所需的水平方向子菜单项。
nav > ul > li ul li {
float: left;
display: inline-block;
}
在这里,我们来到相对于父级定位子菜单的棘手部分。为此,我们对子项使用absolute
定位并为其父项设置position:relative
,以便子项相对于此父项定位,而不是body
元素
nav > ul > li {
position: relative;
}
nav > ul > li ul {
position: absolute;
left: 100px;
top: 0;
}
这是一个有效的演示:http://jsfiddle.net/VCX7T/6/,这是完整的css代码:
nav > ul > li {
clear: left;
position: relative;
}
nav > ul > li ul {
display: none;
}
nav > ul > li:hover ul {
display: block;
}
nav > ul > li ul {
position: absolute;
left: 100px;
top: 0;
}
nav > ul > li ul li {
float: left;
display: inline-block;
}