用纯CSS怎么写适合做栏目分类多的下拉菜单
Admin 2022-06-16 群英技术资讯 752 次浏览
这篇文章给大家分享的是用纯CSS怎么写适合做栏目分类多的下拉菜单。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。这是一款纯CSS实现的大型下拉菜单。该大型菜单使用HTML和纯CSS代码制作,没有任何js代码,不依赖任意第三方插件。适合用于栏目分类较多的大型网站使用。
HTML结构
该大型菜单的HTML结构如下:
<nav>
<ul class="container ul-reset">
<li><a href='#'>Home</a></li>
<li class='droppable'>
<a href='#'>Category One</a>
<div class='mega-menu'>
<div class="container cf">
<ul class="ul-reset">
<h3>Heading 1</h3>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
</ul><!-- .ul-reset -->
<ul class="ul-reset">
<h3>Heading 2</h3>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
</ul><!-- .ul-reset -->
<ul class="ul-reset">
<h3>Heading 3</h3>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
<li><a href='#'>Category One Sublink</a></li>
</ul><!-- .ul-reset -->
<ul class="ul-reset">
<h3>Heading 4</h3>
<li><img src="http://placehold.it/205x172"></li>
</ul>
</div><!-- .container -->
</div><!-- .mega-menu -->
</li><!-- .droppable -->
<li class='droppable'>
<a href='#'>Category Two</a>
<div class='mega-menu'>
<div class="container cf">
<ul class="ul-reset">
<h3>Heading 1</h3>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
</ul><!-- .ul-reset -->
<ul class="ul-reset">
<h3>Heading 2</h3>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
</ul><!-- .ul-reset -->
<ul class="ul-reset">
<h3>Heading 3</h3>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
</ul><!-- .ul-reset -->
<ul class="ul-reset">
<h3>Heading 4</h3>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
<li><a href='#'>Category Two Sublink</a></li>
</ul><!-- .ul-reset -->
</div><!-- .container -->
</div><!-- .mega-menu-->
</li><!-- .droppable -->
<li><a href='#'>Category Three</a></li>
<li><a href='#'>Category Four</a></li>
<li><a href='#'>Category Five</a></li>
<li><a href='#'>Category Six</a></li>
</ul><!-- .container .ul-reset -->
</nav>
CSS
为该大型菜单添加下面的CSS样式:
/* #Resets
–––––––––––––––––––––––––––––––––––––––––––––––––– */
html {box-sizing: border-box;}
*, *:before, *:after {box-sizing: inherit; }
/* #Universal and Default Styles
–––––––––––––––––––––––––––––––––––––––––––––––––– */
body {
background: url(../img/black-wood-small.jpg);
color: #ddd;
font-family: "Open Sans", sans-serif;
font-size: 14px;
line-height: 1;
margin: 0;
padding: 0;
text-align: center;
}
a {text-decoration: none;}
h1 {
font-size: 40px;
font-weight: 700;
margin-bottom: 20px;
margin-top: 20px;
}
h2 {
font-size: 15px;
font-weight: 600;
margin-bottom: 30px;
margin-top: 10px;
}
.container {
margin: auto;
width: 940px;
}
.ul-reset {
padding-left: 0;
margin-top: 0;
margin-bottom: 0;
list-style: none;
}
/* #Navigation Styles
–––––––––––––––––––––––––––––––––––––––––––––––––– */
nav {
background: #424242;
font-size: 0;
position: relative;
}
nav > ul > li {
display: inline-block;
font-size: 14px;
padding: 0 15px;
position: relative;
}
nav > ul > li:first-child {padding-left: 0;}
nav > ul > li:last-child {padding-right: 0;}
nav > ul > li > a {
color: #fff;
display: block;
position: relative;
padding: 20px 0;
border-bottom: 3px solid transparent;
}
nav > ul > li:hover > a {
color: #69aae0;
border-bottom: 3px solid #69aae0;
}
/* #Mega Menu Styles
–––––––––––––––––––––––––––––––––––––––––––––––––– */
.mega-menu {
background: #f0f0f0;
display: none;
left: 0;
position: absolute;
text-align: left;
width: 100%;
}
.mega-menu h3 {color: #444;}
.mega-menu ul {
float: left;
margin-bottom: 20px;
margin-right: 40px;
width: 205px;
}
.mega-menu ul:last-child {margin-right: 0;}
.mega-menu a {
border-bottom: 1px solid #ddd;
color: #4ea3d8;
display: block;
padding: 10px 0;
}
.mega-menu a:hover {color: #2d6a91;}
/* #Droppable Class Styles
–––––––––––––––––––––––––––––––––––––––––––––––––– */
.droppable {position: static;}
.droppable > a:after {
content: "\f107";
font-family: FontAwesome;
font-size: 12px;
padding-left: 6px;
position: relative;
top: -1px;
}
.droppable:hover .mega-menu {display: block;}
/* #Browser Clearfix
–––––––––––––––––––––––––––––––––––––––––––––––––– */
.cf:before,
.cf:after {
content: " "; /* 1 */
display: table; /* 2 */
}
.cf:after {clear: both;}
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
1、减少http请求链接到外部不免增加额外的http请求,这个是很耗时的。2、避免裸页假如存放css的服务器挂掉,整个首页就挂掉了。放在页面内,比较安全。用户访问页面时,不会因为css加载不上,而造成裸页面。3、关于修改你可能说这样不便于修改和管理。实际上一般都是用程序动态加载进来的,然后用缓存静态化首页等。知道的 ...
这篇文章主要介绍了CSS3 中的 transition,transform,translate之间区别和作用,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
本篇文章带大家了解一下CSS3 clip-path(裁剪路径),介绍一下如何利用 clip-path 实现动态区域裁剪,希望对大家有所帮助!
单纯用css实现切角+边框+投影+内容背景色渐变所有效果,因为UI没给背景切图,寻思这个理论上用css就能实现。看一下最终要实现的效果:首先不谈内容紫蓝色渐变,一个单纯的四切角+黑
这篇文章主要介绍了CSS多级菜单的实现代码的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008