如何使用CSS创建一个嵌套的垂直菜单,并带有水平子菜单。

3

我想把一个列表垂直排列,但在更改了很多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>
1个回答

3

如果您想让父菜单垂直排列(依次向下),而嵌套的子菜单水平排列(彼此向左),那么请参考以下HTML标记:

假设这是我们的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>​

为了定位父菜单项,我们只需要告诉它们清除其左侧的浮动。这样就不会有任何元素向其右侧浮动:
nav > ul > li {
    clear: left;
}

请注意,为了指定只有父菜单项,我们使用了子组合器>。因此,这个样式不会影响内部的li,只有父级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;
}​

在 CSS 代码中,">" 是什么意思?例如 nav>ul>li ul li 意味着在 nav 内部的 ul 中的 li ul li? - Ant Mar
这是一个详细的答案:https://dev59.com/bHA75IYBdhLWcg3wkJ71 - Arash Milani
太好了,很高兴听到这个消息。同时请考虑删除上面的任何闲聊和不必要的评论,如果您认为这对问题的未来访问者没有用处的话。 - Arash Milani

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接