我现在已经挣扎了好几天试图做这项工作 - 我开始看到一些尚未创造出来的东西浮现在我眼前。
问题是我需要使用只有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>
答案 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。
请注意,只有第一个版本在语义上正确。其他版本只提供一些更简单的样式。