【发布时间】:2014-02-15 19:09:04
【问题描述】:
我正在创建一个垂直导航,其中列表项是圆圈。子菜单项应从其父项飞出。
我有工作代码,但该代码仅适用于单个子菜单,因为它需要大量使用 'left' 和 'top' 属性来定位子菜单列表项。我敢打赌,如果有更多的子菜单,这看起来会很漂亮,但是根据我的口味,每个菜单都需要过多的 CSS 自定义。
<nav>
<ul class="menu">
<li><a href="/">Home Page</a></li>
<li><a href="/">About</a>
<ul>
<li><a href="/">Our History</a></li>
<li><a href="/">Our Philosophy</a></li>
<li><a href="/">Our Mission</a></li>
</ul>
</li>
<li><a href="/">Services</a></li>
<li><a href="/">Our Team</a></li>
<li><a href="/">Contact Us</a></li>
</ul>
</nav>
CSS
/* Circle Menu */
nav {
width: 10em;
}
.menu a{
display: block;
padding:10px;
width: 100%;
height: 7.5em;
border-radius: 750px 750px 750px 750px;
-moz-border-radius: 750px 750px 750px 750px;
-webkit-border-radius: 750px 750px 750px 750px;
background-color: hsl(0, 100%, 72%);
text-align: center;
margin-bottom: 1em;
}
.menu li{
margin-bottom: 1em;
list-style: none;
}
.menu li ul{
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
opacity: 0;
padding: 0;
display: inline;
top: -8em;
position: fixed;
}
.menu li:hover ul{
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
padding: 0;
opacity: 1;
}
.menu ul li a{
width: 100%;
background-color: hsl(0, 60%, 72%);
}
.menu li ul li {
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
position:relative;
left:0;
}
.menu li:hover ul li {
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
position: relative;
left: 190px;
}
.menu li ul li:nth-child(1) {
top: 307px;
left: 0px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li:hover ul li:nth-child(1) {
top: 150px;
left: 160px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li ul li:nth-child(2) {
top: 153px;
left: 0;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li:hover ul li:nth-child(2) {
left: 240px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
top: 150px;
}
.menu li ul li:nth-child(3) {
top: -5px;
left: 0;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li:hover ul li:nth-child(3) {
top: 153px;
left: 160px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
Demo that breaks because there are 2 submenus.
<nav>
<ul class="menu">
<li><a href="/">Home Page</a></li>
<li><a href="/">About</a>
<ul>
<li><a href="/">Our History</a></li>
<li><a href="/">Our Philosophy</a></li>
<li><a href="/">Our Mission</a></li>
</ul>
</li>
<li><a href="/">Services</a></li>
<li><a href="/">Our Team</a>
<ul>
<li><a href="/">Jim</a></li>
<li><a href="/">Karla</a></li>
<li><a href="/">Manzanita</a></li>
</ul>
</li>
<li><a href="/">Contact Us</a></li>
</ul>
</nav>
CSS
/* Circle Menu */
nav {
width: 10em;
}
.menu a{
display: block;
padding:10px;
width: 100%;
height: 7.5em;
border-radius: 750px 750px 750px 750px;
-moz-border-radius: 750px 750px 750px 750px;
-webkit-border-radius: 750px 750px 750px 750px;
background-color: hsl(0, 100%, 72%);
text-align: center;
margin-bottom: 1em;
}
.menu li{
margin-bottom: 1em;
list-style: none;
}
.menu li ul{
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
opacity: 0;
padding: 0;
display: inline;
top: -8em;
position: fixed;
}
.menu li:hover ul{
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
padding: 0;
opacity: 1;
}
.menu ul li a{
width: 100%;
background-color: hsl(0, 60%, 72%);
}
.menu li ul li {
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
position:relative;
left:0;
}
.menu li:hover ul li {
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
position: relative;
left: 190px;
}
.menu li ul li:nth-child(1) {
top: 307px;
left: 0px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li:hover ul li:nth-child(1) {
top: 150px;
left: 160px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li ul li:nth-child(2) {
top: 153px;
left: 0;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li:hover ul li:nth-child(2) {
left: 240px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
top: 150px;
}
.menu li ul li:nth-child(3) {
top: -5px;
left: 0;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
.menu li:hover ul li:nth-child(3) {
top: 153px;
left: 160px;
-webkit-transition:all .35s ease-in;
-moz-transition:all .35s ease-in;
-o-transition:all .35s ease-in;
transition:all .35s ease-in;
}
是否可以仅使用 CSS 为多个子菜单创建我想要的效果,而无需单独定位每个子菜单项?还是我需要使用 JavaScript 为我“自动”定位元素?
【问题讨论】:
-
我认为这很糟糕,因为您在这里使用了固定/相对定位的组合……我会让主菜单项保持正常流程,并给它们
position:relative,以便它们绝对定位子元素将它们作为方向点……
标签: html css navigation