banner

纯CSS导航下拉效果,神奇的定位与显示属性

导航下拉,大家首先想到的是用JS来做。或许是大家看到的下拉菜单演示,多是JS控制的下拉,导致从先入为主的意识上,误以为二级下拉是很难的东西,必须要会Javascript才能做。

其实,一个简答的下拉效果,根本不需要JS也能做。比如,我目前在用的Yuan,以及之前用的趣儿等,所用的下拉,都是利用CSS来做,而且还是CSS2,兼容性也不错(除了IE6)。

下拉导航效果图

在分享CSS效果之前,我觉得,应该对当前的需求,做一个分析,这样能够更加理解为什么要运用的这些CSS属性。

逻辑:有一个一级导航是可见的;而要下拉的二级导航在未触发设定的条件之前,是不可见的。其中二级导航的逻辑一般都是:li一级导航>ul>li二级导航

条件:当我们的鼠标移到一级导航上时,二级导航显示(变为可见的)。

在常见的导航中,大多都是使用的ul>li的结构做的导航条。在忽略条件的情况下,如果要正常显示二级导航,那么就应让二级导航下拉出现在对应的位置。无疑,此处应该采用的是CSS的定位,即position属性。

再来分析一下,position有哪些属性值:relative(相对定位)、absolute(绝对定位)、static(正常的)、fixed(基于浏览器窗口固定的)。

要在对应一级导航下面出现二级导航,我们就需要使用absolute绝对定位来帮助我们定位,根据绝对定位是依据前一个relative(如果没有,就是根据当前html文档)来做的绝对定位。所以,在代码中要为一级导航的li选择器声明内,添加一个position:relative;。

li {position:relative;width:100px;height:40px;}/*此处假设宽为100px,高为40px*/

在添加完以后,继续为一级导航的li加一个后代选择器,li ul,然后加入声明,position:absolute;

li ul {position:absolute;top:40px;left:0;width:100px;}/*此处假设宽为100px*/

当然,这里是需要加入上下左右的值做定位的,这个根据父级li的宽度和高度,自行设定。

好了,现在已经把位置搞定了,继续分析下一个需求,显示和隐藏二级导航。

在CSS当中,显示和隐藏的属性就是display了。display的none为隐藏,block或inline-block都可以用做显示。(这里我不阐述display的那些基本内容,如果不清楚,点击此处

在文档正常加载时,条件未触发前,二级导航是隐藏的。所以,要为li ul选择器加入一个display:none;

li ul {position:absolute;top:40px;left:0;width:100px;display:none;}

最后,再分析一下如何用CSS触发条件。写过a标签的style,或许大家都清楚,有一个伪类:hover是鼠标指针放到a标签上后,可以改变a标签的style样式的。此处用伪类:hover最合适不过了,而且伪类:hover并非是a标签的专有伪类。

将给一级导航的li单独写一个选择器,用处触发条件。条件触发以后,显示二级导航ul中的内容。

li:hover ul {display:block;}/*用display:block将ul变为正常显示*/

好了,一个简单的下拉效果就做出来了,剩下的就是配合网站的模板再添加一些颜色等属性的搭配了。

总结:

使用纯CSS做下拉效果的要点:定位(position)、显示/隐藏(display)、伪类(:hover),这三个是必要的内容,缺一不可。

这种方法的优点:加载快、兼容好;缺点:无法对下拉显示做CSS3动画(至少目前的我,没办法做到……)

CSS代码:

li {position:relative;width:100px;height:40px;}/*此处假设宽为100px,高为40px*/
li ul {position:absolute;top:40px;left:0;width:100px;display:none;}/*此处假设宽为100px*/
li:hove ul {display:block;}/*用display:block将ul变为正常显示*/

有一点要提醒的是,在CSS代码的整体控制中,如果绝对定位的任意父级使用了overflow:hidden;隐藏溢出的,那么定位的内容显示,是不会超出这个层的。

【原创经验文章,转载务必注明出处!】

阅读: 6572
在同意共创许可协议(CC BY-NC-SA-4.0)的前提下,您可以转载本文。
橙色阳光
https://oss.so/article/58

相关阅读

留言评论

12条留言
airicy
第三句hover少了个r,怪不得怎么都实现不了
橙色阳光
额,好吧,是我的错,马上补上
黎叔
没错就是要简洁
小越
访客好教程,谢谢分享!收藏了
邦尼
只能说CSS太强大了,没有做不到只有想不到...
访客小幻
分析的很透彻
WholesalePurses
好教程,谢谢分享!收藏了 。
纯正土蜂蜜
相信我以后用的上吧,谢谢博主
微历史
前端挺有意思的,这就是你顶部的菜单效果吧
威客百科
学了一个多月的css,这段时间看得少了,感觉就忘得差不多了
脑精网福利
这个用在手机里效果怎么样?手机里菜单不怎么好用,平铺在菜单一栏才比较好,不小心点击会只打开第一层。
橙色阳光
手机上肯定要单独做,这个是电脑上的