第二个选择器悬停不在多级深度菜单中工作

时间:2014-05-20 13:04:55

标签: jquery css html5 nav multi-level

我现在已经挣扎了好几天试图做这项工作 - 我开始看到一些尚未创造出来的东西浮现在我眼前。

问题是我需要使用只有CSS和HTML的ZERO Java或JQuery构建一个多级导航系统。

代码的来源将从ASP应用程序生成,因此导航系统的详细信息将存储在数据库中。因此,我可以在代码之外维护ID值和所有其他关系方面。

主要问题是试图找到足够的信息来帮助我理解:HOVER动作是如何工作的 - 因为我不能让其他级别对主级别的HOVER做出反应。

我需要的是2级菜单变得可见,并且只显示主菜单悬停时的相关选项。当您将鼠标悬停在下一级别时,相关菜单也只会打开。

用户不得在网站上点击超过3次,因此我需要快速,顺利地公开所有选项,因此我只需点击一下即可在此示例中进行最终选择 - 将鼠标悬停在每个选项之后选项。

请帮忙。

我的CSS代码:

a {text-decoration:none;}
.L2:before {content:"["}
.L2:after {content:"]"}


.L1{
   width:30em;
   padding:6px;
   margin:6px;
   background-color:cyan;
   border-style:groove;
   width:120px;
   text-align:center;
   position:relative;
   display:inline;
   vertical-align:text-top;
   border-style:groove;
   height:2.5em;
   border-radius:10px 10px 10px 10px;
   z-index:1;
   visibility:visible;
}

.mnuL2 {
border-style:groove;
border-radius:10px 10px 10px 10px;
background-color:cyan;
}
.divider {
border-bottom-style:dashed;
}
    .Level2{
    width:20em;
    height:1.8em;
    visibility:hidden;
}

div[id^=mnu1] {
    position:absolute;
    padding:4px;
    margin:0 10px 0 0;
    display:inline;
    top:1.85em;
    visibility:visible;
}

div[id^=mnu2] {
    position:absolute;
    padding:4px;
    display:inline;
    top:1.85em;
    left:5px;
    /*visibility:visible;*/
}

.Level3 {
    visibility:hidden;
}


div[id^=One] {
    position:relative;
    top:5px;
    left:16px;
    display:list-item;
    /*visibility:visible;*/
    z-index:10;
}

div[id^=Two] {
    position:relative;
    top:5px;
    left:16px;
    display:list-item;
    visibility:visible;
    z-index:10;
}


.L1:hover{
   background:lightgray;
}


.L1:hover div[id^=mnu1]{
   background:lightgray;
   font-style:italic;
}

我的HTML代码

<!DOCTYPE html>
<html>
<head>
    <link href="OneStyle.css" rel="stylesheet" type="text/css" />
</head>


<body>


<div id="NavSys">
    <div class="mnuParent">
       <div class=L1 id=mnu01><a href="#"> One</a></div>
       <div class=L1 id=mnu02><a href="#">Two</a></div>
       <div class=L1 id=mnu03><a href="#">Three</a></div>
    </div>

    <div class="mnuL2">
        <div Class="Level2">
           <div class="L2"  id="mnu11"><a href="#">One-001</a></div>
           <div class="L2" id="mnu12"><a href="#">One-002</a></div>
           <div class="L2" id="mnu21"><a href="#">Two-001</a></div>
           <div class="L2" id="mnu22"><a href="#">Two-002</a></div>
           <div class="L2" id="mnu31"><a href="#">Three-001</a></div>
           <div class="L2" id="mnu32"><a href="#">Three-002</a></div>
         </div>
        <div class="divider"></div>
        <div class="Level3">
           <div class="L3" id="One11"><a href="#">One11</a></div>
           <div class="L3" id="One12"><a href="#">One12</a></div>
           <div class="L3" id="One21"><a href="#">One21</a></div>
           <div class="L3" id="One22"><a href="#">One22</a></div>
           <div class="L3" id="Two11"><a href="#">Two11</a></div>
           <div class="L3" id="Two12"><a href="#">Two12</a></div>
           <div class="L3" id="Two21"><a href="#">Two21</a></div>
           <div class="L3" id="Two22"><a href="#">Two22</a></div>
           <div class="L3" id="Three11"><a href="#">Three11</a></div>
           <div class="L3" id="Three12"><a href="#">Three12</a></div>
           <div class="L3" id="Three21"><a href="#">Three21</a></div>
           <div class="L3" id="Three22"><a href="#">Three22</a></div>
       </div>
    </div>
</div>


</body>
</html>

2 个答案:

答案 0 :(得分:1)

通常在创建纯CSS下拉菜单系统时,子菜单项将嵌套在父按钮中(每个菜单和子菜单通常标记为无序列表)。

您尝试做的事情永远无法发挥作用,因为您正在尝试定位一个元素,该元素位于DOM的上方而不是正在悬停的元素上。 CSS可以遍历DOM树,但不能遍历。

以下是如何创建纯CSS下拉菜单。

我认为您的标记不是一成不变的,并且您实际上可以移动菜单以便它们嵌套在包含li的内容中。

HTML:

<ul class="menu">
    <li>
        <a href="#">One</a>
        <ul class="menu">
            <li><a href="#">Sub1 A</a></li>
            <li>
                <a href="#">Sub1 B</a>
                <ul class="menu">
                    <li><a href="#">Sub2 A</a></li>
                    <li><a href="#">Sub2 B</a></li>
                    <li><a href="#">Sub2 C</a></li>
                </ul>
            </li>
            <li><a href="#">Sub1 C</a></li>
        </ul>
    </li>
    <li><a href="#">Two</a></li>
    <li><a href="#">Three</a></li>
</ul>

CSS:

.menu {
    padding: 0;
    margin: 0;
}
.menu .menu {
    display: none;
    position: absolute;
    left: 0;
    width: 200px;
}
.menu .menu .menu {
    left: 100%;
    top: 0;
}
.menu li {
    position: relative;
    float: left;
    list-style: none;
}
.menu .menu li {
    float: none;
}
.menu li:hover > .menu {
    display: block;
}
.menu a {
    display: block;
    border: 1px solid #fff;
    padding: 10px;
    background: lightgray;
}

这是一个显示此菜单的小提琴:http://jsfiddle.net/x9TnS/

这是一个基本的概念验证,您可以通过搜索&#34;纯css下拉菜单找到更多详细的教程&#34;。

答案 1 :(得分:0)

要完成这项工作,您必须:

在触发元素中添加关卡内容(首选版本)( click for Fiddle

UL
 |- LI
 |- LI (trigger 1)
 |   |
 |   UL (content 1)
 |   |- LI
 |   |- LI
 |   |- LI
 |
 |- LI (trigger 2)
 |   |
 |   UL (content 2)
 |   |- LI
 |   |- LI
 |   |- LI
 |
 |- LI

OR

在触发元素旁边添加关卡内容( click for Fiddle

NAV
 |- DIV (trigger 1)
 |- DIV (content 1)
 |- DIV (trigger 2)
 |- DIV (content 2)

OR

在触发元素之后的某处添加关卡的内容( click for Fiddle

NAV
 |- DIV (trigger 1)
 |- DIV (trigger 2)
 |- DIV (content 1)
 |- DIV (content 2)

任何其他结构都不适用于纯CSS。

请注意,只有第一个版本在语义上正确。其他版本只提供一些更简单的样式。