0

我在使用下拉菜单时遇到问题。当导航的内容根据其宽度和菜单项相互堆叠的情况进行换行时,此时子菜单出现在距它一定距离处,并在我悬停之前消失。帮助!我正在处理这段代码。小提琴链接如下。

<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;
}

小提琴

4

1 回答 1

0

有几种解决方案。

解决方案 1

设置主UL元素的宽度。所以菜单不会在调整大小时中断。


解决方案 2

以百分比或 em 为单位设置大小,尤其是font-size,以便所有内容都可以缩放并且易于调整大小。


解决方案 3(可选)

使用响应式设计,并针对不同的分辨率(460 - 760、760 - 960、1000+)调整菜单。这需要更多的工作,但它的回报更大。:)

于 2013-04-04T11:45:59.663 回答