我在下拉菜单中遇到问题。当导航内容根据其宽度和菜单项彼此堆叠时的情况进行包装时,此时子菜单与其相距一定距离并在我悬停在其上之前消失。救命!我正在研究这段代码。小提琴在下面链接。
<nav>
<ul>
<li><a href="#">Home</a></li>
<li><a href="#">Menu1</a>
<ul>
<li><a href="#">Option1</a></li>
<li><a href="#">Option2</a></li>
<li><a href="#">Option3</a>
<ul>
<li><a href="#">Sub-option1</a></li>
<li><a href="#">Sub-option2</a></li>
</ul>
</li>
</ul>
</li>
<li><a href="#">Menu2</a>
<ul>
<li><a href="#">Option1</a></li>
<li><a href="#">Option2</a></li>
</ul>
</li>
<li><a href="#">Menu3</a></li>
</ul>
CSS:
nav ul ul {
display: none;
}
nav ul li:hover > ul {
display: block;
}
nav ul {
box-shadow: 0px 0px 9px rgba(0,0,0,0.15);
padding: 0 20px;
list-style: none;
position: relative;
display: inline-table;
}
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 {
float: none;
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;
}
答案 0 :(得分:0)
有几种解决方案。
解决方案1
设置主 UL 元素的宽度。所以菜单不会在调整大小时中断。
解决方案2
以百分比或em为单位设置尺寸,尤其是 font-size ,以便所有内容都具有可扩展性且易于调整大小。
解决方案3(可选)
使用响应式设计,并调整不同分辨率的菜单(460 - 760,760 - 960,1000 +)。这需要更多的工作,但它的回报更大。 :)