我想让纯css水平导航与垂直子菜单和水平子菜单的子菜单



我想修复这个小提琴,你可以看到它工作不好。我想让这个导航水平,子菜单垂直,子菜单水平,但问题是我也使用了转换,但它不正确。第一个子菜单不能平滑地下降,但可以平滑地滚动,第三个子菜单不能像平滑滚动和滚动一样工作。我想解决这个问题,我想知道如何解决这个问题。这是小提琴,所有代码都包含此项。http://jsfiddle.net/hsn0/nQneb/

css

#nav {
height: auto;
width: auto;
}
#nav ul {
margin: 0px;
padding: 0px;
list-style-type: none;
}
#nav ul li {
float: left;
position: relative;
}
#nav ul li a {
line-height: 30px;
text-decoration: none;
text-align: center;
display: block;
width: 100px;
height: 30px;
border: thin solid #999;
color: #FFF;
background-color: #0CF;
-webkit-transition: all 1s;
-moz-transition: all 1s;
-ms-transition: all 1s;
-o-transition: all 1s;
transition: all 1s;
 }
 #nav ul li a:hover {
background-color: #0C3;
 }
 #nav ul li ul {
position: absolute;
visibility: hidden;
-webkit-transition: all 1s linear 0s;
-moz-transition: all 1s linear 0s;
-ms-transition: all 1s linear 0s;
-o-transition: all 1s linear 0s;
transition: all 1s linear 0s;
overflow: hidden;
height: 0px;
 }
 #nav ul li:hover ul {
height: 100px;
visibility: visible;
overflow: visible;
 }
 #nav ul li ul li {
-ms-transition: all 1s;
-o-transition: all 1s;
 }
 #nav ul li ul li a {
background-color: #666;
-webkit-transition: all 1s;
-moz-transition: all 1s;
-ms-transition: all 1s;
-o-transition: all 1s;
transition: all 1s;
 }
 #nav ul li ul li a:hover {
background-color: #C30;
 }
 #nav ul li ul li ul {
position: absolute;
left: 102px;
top: 0px;
display: none;
-webkit-transition: all 1s ease 0s;
-moz-transition: all 1s ease 0s;
-ms-transition: all 1s ease 0s;
-o-transition: all 1s ease 0s;
transition: all 1s ease 0s;
overflow: hidden;
visibility: hidden;
width: 0px;
 }
 #nav ul li ul li ul li {
float: left;
position: relative;
 }
 #nav ul li ul li:hover ul {
width: 104px;
display: block;
/* [disabled]overflow: visible; */
visibility: visible;
 }
 **html**
<nav id="nav">
 <ul>
   <li><a href="#">Item1</a>
 <ul>
   <li><a href="#">Sub1</a></li>
  <li><a href="#">Sub1</a></li>
   <li><a href="#">Sub1</a>
     <ul>
 <li><a href="#">Sub2</a></li>
        <li><a href="#">Sub2</a></li>
        <li><a href="#">Sub2</a></li>
     </ul>
    </li>
   </ul>
  </li>
 </ul>
</nav>

请查看此演示

我觉得主要的问题是由于可见性和溢出,我们可以转换不透明度和高度。

我用了几个菜单部分。。。我试过身高,尽管它也适用于所有人。

#nav ul li ul {
    position: absolute; 
    -webkit-transition: height  1s linear 0s;
    -moz-transition: height  1s linear 0s;
    -ms-transition: height  1s linear 0s;
    -o-transition: height  1s linear 0s;
    transition: height 1s linear 0s;    
    height: 0px;
    overflow:hidden;
}
#nav ul li:hover ul {
    height: 100px;
        -webkit-transition: height 1s linear 0s;
    -moz-transition: height 1s linear 0s;
    -ms-transition: height 1s linear 0s;
    -o-transition: height 1s linear 0s;
    transition: height 1s linear 0s;
}

我希望下面的css能解决你的问题

         #nav {
            height: auto;
            width: auto;
        }
        #nav ul {
            margin: 0px;
            padding: 0px;
            list-style-type: none;
        }
        #nav ul li {
            float: left;
            position: relative;
        }
        #nav ul li a {
            line-height: 30px;
            text-decoration: none;
            text-align: center;
            display: block;
            width: 100px;
            height: 30px;
            border: thin solid #999;
            color: #FFF;
            background-color: #0CF;
            -webkit-transition: all 0.3s ease-out;
            -moz-transition: all 0.3s ease-out;
            -o-transition: all 0.3s ease-out;
            /*transition: all 0.3s ease-out;*/
            transition:display 0s linear 0.5s,opacity 0.5s linear;
        }
        #nav ul li a:hover {
            background-color: #0C3;
        }
        #nav ul li ul {
            position: absolute;
            height:0;
            visibility:hidden;
            opacity:0;
            -webkit-transition: all 1s ease-out;
            -moz-transition: all 1s ease-out;
            -o-transition: all 1s ease-out;
            transition: all 1s ease-out;
        }
        #nav ul li:hover ul {
            opacity:1;
            visibility:visible; 
            overflow: visible;
        }
        #nav ul li ul li a {
            background-color: #666;
            -webkit-transition: all 0.3s ease-out;
            -moz-transition: all 0.3s ease-out;
            -o-transition: all 0.3s ease-out;
            transition: all 0.3s ease-out;
        }
        #nav ul li ul li a:hover {
            background-color: #C30;
        }
        #nav ul li ul li ul {
            position: absolute;
            left: 102px;
            top: 0px;
            visibility:hidden !important;
            opacity:0 !important;
            -webkit-transition: all 1s ease-out;
            -moz-transition: all 1s ease-out;
            -o-transition: all 1s ease-out;
            transition: all 1s ease-out;
            overflow: hidden;
        }
        #nav ul li ul li:hover .last {
            opacity:1 !important;
            visibility:visible !important;
            overflow: visible;
        }
        #nav ul li ul li .last li{
            float: left;
            position: relative;
        }
        #navul li ul li .last li a {
            line-height: 30px;
            text-decoration: none;
            text-align: center;
            display: block;
            width: 100px;
            height: 30px;
            border: thin solid #999;
            color: #FFF;
            background-color: #0CF;
            -webkit-transition: all 0.3s ease-out;
            -moz-transition: all 0.3s ease-out;
            -ms-transition: all 0.3s ease-out;
            -o-transition: all 0.3s ease-out;
            transition: all 0.3s ease-out;
        }

HTML

        <nav id="nav">
          <ul>
            <li><a href="#">Item1</a>
            <ul>
              <li><a href="#">Sub1</a></li>
              <li><a href="#">Sub1</a></li>
                <li><a href="#">Sub1</a>
                 <ul class="last">
                    <li><a href="#">Sub2</a></li>
                    <li><a href="#">Sub2</a></li>
                    <li><a href="#">Sub2</a></li>
                 </ul>
                </li>
            </ul>
            </li>
          </ul>
        </nav>

相关内容

  • 没有找到相关文章

最新更新