纯CSS实现兼容IE7及以上宽度自适应无限级导航菜单附演示
前端  /  管理员 发布于 7年前   283
先来个Demo:
https:///jiaoben/111258.html
好吧,我承认,我有点标题党了,IE7的兼容并不是特别好,当鼠标离开某个导航再进入时,会留下上一次子菜单的残影(写的好像玄幻小说似的=。=)
不过纯属研究,O(∩_∩)O哈哈~
宽度自适应是指各级菜单都可以随内容的长度自行适应宽度,而当浏览器分辨率较低时一级导航也可以自动换行,而多级子菜单靠左显示还是得手动调整。
DOM结构比较简单,只是 ol.nav 与 li.item 的互相嵌套而已。
看代码吧(长是长了点,但其实你会发现导航的标签结构真的真的很简单,重要的是CSS部分):
复制代码代码如下:
<!doctype html>
<html lang="zh-CN">
<head>
<meta charset="UTF-8">
<title>无限级纯CSS导航菜单</title>
<style type="text/css">
.nav{
margin: 0;
padding: 0;
float: left;
list-style: none;
background: #222;
}
.nav a{
color: #ddd;
display: block;
padding: 0 15px;
text-decoration: none;
}
.nav a:hover{
color: #2FAADD;
}
.nav .item{
margin: 0;
padding: 0;
float: left;
height: 35px;
line-height: 35px;
white-space: nowrap;
}
.nav .item:hover>a{
color: #2FAADD;
}
.nav .item:hover>.nav{
display: block;
}
.nav .nav{
top: 100%;
left: 0;
display: none;
background: #444;
position: absolute;
border: 1px solid #888;
}
.nav .nav .item{
clear: both;
min-width: 100%;
}
.nav .nav .nav{
top: -1px;
left: 100%;
}
.nav .nav .nav .nav .nav .nav{
left: auto;
right: 100%;
}
</style>
</head>
<body>
<ul class="nav">
<li class="item"><a href="">一级导航 1</a>
<ul class="nav">
<li class="item"><a href="">二级导航 1</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 2</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">无子导航 3</a></li>
<li class="item"><a href="">二级导航 4</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">无子导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">长长的一级导航 2</a>
<ul class="nav">
<li class="item"><a href="">二级导航 1</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 2</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">更长的二级导航 3</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">低调的三级导航 5</a>
<ul class="nav">
<li class="item"><a href="">四级导航 1</a></li>
<li class="item"><a href="">藏的很深的四级导航 2</a>
<ul class="nav">
<li class="item"><a href="">藏的更深的五级导航 0</a></li>
<li class="item"><a href="">五级导航 1</a></li>
<li class="item"><a href="">五级导航 2</a></li>
<li class="item"><a href="">五级导航 3</a></li>
<li class="item"><a href="">五级导航 4</a></li>
<li class="item"><a href="">下面该往左了吧</a>
<ul class="nav">
<li class="item"><a href="">我在左边</a></li>
<li class="item"><a href="">我真的在左边</a></li>
<li class="item"><a href="">我就要赖在左边</a></li>
<li class="item"><a href="">杨丞琳的左边好听</a></li>
<li class="item"><a href="">呜呜,今年双十一又要过节</a></li>
<li class="item"><a href="">妹纸妹纸在哪里?</a></li>
</ul>
</li>
</ul>
</li>
<li class="item"><a href="">四级导航 3</a></li>
<li class="item"><a href="">四级导航 4</a></li>
<li class="item"><a href="">四级导航 5</a></li>
</ul>
</li>
</ul>
</li>
<li class="item"><a href="">二级导航 4</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 5</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
</ul>
</li>
<li class="item"><a href="">无子导航 3</a></li>
<li class="item"><a href="">一级导航 4</a>
<ul class="nav">
<li class="item"><a href="">二级导航 1</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 2</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 3</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 4</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
<li class="item"><a href="">二级导航 5</a>
<ul class="nav">
<li class="item"><a href="">三级导航 1</a></li>
<li class="item"><a href="">三级导航 2</a></li>
<li class="item"><a href="">三级导航 3</a></li>
<li class="item"><a href="">三级导航 4</a></li>
<li class="item"><a href="">三级导航 5</a></li>
</ul>
</li>
</ul>
</li>
<li class="item"><a href="">一级导航 5</a>
<ul class="nav">
<li class="item"><a href="">无子导航 1</a></li>
<li class="item"><a href="">无子导航 2</a></li>
<li class="item"><a href="">无子导航 3</a></li>
<li class="item"><a href="">无子导航 4</a></li>
<li class="item"><a href="">无子导航 5</a></li>
</ul>
</li>
</ul>
</body>
</html>
不过如果要探讨实用性的话,还是需要用JavaScript来兼容IE6下li不支持hover伪类的BUG,改动也很简单,也来个Demo:
https:///jiaoben/111260.html
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号