!
也想出现在这里? 联系我们
广告位

纯CSS3实现手风琴风格菜单具体步骤

有朋友问我,我的 demo 里面的手风琴效果怎么做出来,看起来很漂亮,其实这个手风琴效果没用一点 js,全部用 css3 来实现的,菜单主要通过使用:target 伪类来实现,教程中我们主要通过使用伪类:before 和:target 来定义样式,使用:target 来实现菜单点击展开子菜单事件,希望你能够喜欢这个教程:

如何使用纯 CSS3 创建手风琴风格菜单呢,菜单主要通过使用:target 伪类来实现,教程中我们主要通过使用伪类:before 和:target 来定义样式,使用:target 来实现菜单点击展开子菜单事件。

:target 使用介绍

CSS3 target 伪类是众多实用的 CSS3 特性中的一个。它用来匹配文档(页面)的 URI 中某个标志符的目标元素。具体来说,URI 中的标志符通常会包含一 个”#”字符,然后后面带有一个标志符名称,比如#respond,target 就是用来匹配 ID 为 respond 的元素的。

现在在页面中,点击一个 ID 链接后,页面只会跳转到相应的位置,但是并不会有比较明显的 UI 标识,使用:target 伪类可以像:hover 等伪类一样对目标元素定义样式。

第一步:HTML 标签结构

一 个简单的无序列表,每个 li 中包含一个超链接和 span,同时为每一个 li 添加一个不同的 id 和一个连接到这个 id 的超链接。为了添加样式和展开菜单项下 面的内容,需要使用:target 伪类。

  1. <ul class="accordion">
  2. <li id="one" class="files"><a href="#one">我的文件<span>495</span></a></li>
  3. <li id="two" class="mail"><a href="#two">邮件<span>26</span></a></li>
  4. <li id="three" class="cloud"><a href="#three">网盘<span>58</span></a></li>
  5. <li id="four" class="sign"><a href="#four">退出登录</a></li>
  6. </ul>

第二步:菜单布局基本样式

  1. .accordion,
  2. .accordion ul,
  3. .accordion li,
  4. .accordion a,
  5. .accordion span {
  6. margin: 0;
  7. padding: 0;
  8. border: none;
  9. outline: none;
  10. text-align:left;
  11. }
  12. .accordion li {
  13. list-style: none;
  14. }

定义菜单项链接样式,添加渐变,阴影的效果,定义字体等。这里没有指定固定的宽度,菜单的 宽度 100%填充它的父元素,如果你想把菜单设置成 300px,你可以给它添加一个父 div,指定宽度为 300px 就可以了。虽然没有指定宽度,但是定义 了最小宽度,保证菜单布局能够正确的显示。

  1. .accordion li > a {
  2. display: block;
  3. position: relative;
  4. min-width: 110px;
  5. padding: 0 10px 0 40px;
  6. color: #fdfdfd;
  7. font: bold 14px/32px 黑体,宋体;
  8. text-decoration: none;
  9. text-shadow: 0px 1px 0px rgba(0,0,0, .35);
  10. background: #6c6e74;
  11. background: -moz-linear-gradient(top, #6c6e74 0%, #4b4d51 100%);
  12. background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#6c6e74), color-stop(100%,#4b4d51));
  13. background: -webkit-linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
  14. background: -o-linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
  15. background: -ms-linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
  16. background: linear-gradient(top, #6c6e74 0%,#4b4d51 100%);
  17. -webkit-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
  18. -moz-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
  19. box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
  20. }

定义数字指示器样式,当然如果你的菜单不需要数字指示器,你打可以删掉这个 html 结构中 span 元素。

  1. .accordion li > a span {
  2. display: block;
  3. position: absolute;
  4. top: 7px;
  5. right: 0;
  6. padding: 0 10px;
  7. margin-right: 10px;
  8. font: normal bold 12px/18px Arial, sans-serif;
  9. background: #404247;
  10. -webkit-border-radius: 15px;
  11. -moz-border-radius: 15px;
  12. border-radius: 15px;
  13. -webkit-box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
  14. -moz-box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
  15. box-shadow: inset 1px 1px 1px rgba(0,0,0, .2), 1px 1px 1px rgba(255,255,255, .1);
  16. }

第三步:添加图标样式

我们使用:before 为菜单插入图标,图标的宽 高都是 24px,用下面的样式使其正确的显示。我创建了一个 sprite,包含了四个图标的正常和 hover 时候的不同样式。

  1. .accordion > li > a:before {
  2. position: absolute;
  3. top: 0;
  4. left: 0;
  5. content: '';
  6. width: 24px;
  7. height: 24px;
  8. margin: 4px 8px;
  9. background-repeat: no-repeat;
  10. background-image: url(../images/icons.png);
  11. background-position: 0px 0px;
  12. }
  13. .accordion li.files > a:before { background-position: 0px 0px; }
  14. .accordion li.files:hover > a:before,
  15. .accordion li.files:target > a:before { background-position: 0px -24px; }
  16. .accordion li.mail > a:before { background-position: -24px 0px; }
  17. .accordion li.mail:hover > a:before,
  18. .accordion li.mail:target > a:before { background-position: -24px -24px; }
  19. .accordion li.cloud > a:before { background-position: -48px 0px; }
  20. .accordion li.cloud:hover > a:before,
  21. .accordion li.cloud:target > a:before { background-position: -48px -24px; }
  22. .accordion li.sign > a:before { background-position: -72px 0px; }
  23. .accordion li.sign:hover > a:before,
  24. .accordion li.sign:target > a:before { background-position: -72px -24px; }

第四步:子菜单 HTML 和样式

同样也使用 ul 作为子菜单,放到父菜单的 li 里面,如下代码

  1. <li id="one"><a href="#one">我的文件<span>495</span></a>
  2. <ul>
  3. <li><a href="javascript:void(0);"><em>01</em>音乐<span>42</span></a></li>
  4. <li><a href="javascript:void(0);"><em>02</em>视频<span>87</span></a></li>
  5. <li><a href="javascript:void(0);"><em>03</em>图片<span>366</span></a></li>
  6. </ul>
  7. </li>
  1. .sub-menu li a {
  2. font: bold 12px/32px 黑体,宋体;
  3. color: #797979;
  4. text-shadow: 1px 1px 0px rgba(255,255,255, .2);
  5. background: #e5e5e5;
  6. border-bottom: 1px solid #c9c9c9;
  7. -webkit-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
  8. -moz-box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
  9. box-shadow: inset 0px 1px 0px 0px rgba(255,255,255, .1), 0px 1px 0px 0px rgba(0,0,0, .1);
  10. }
  11. .sub-menu li:last-child a { border: none; }
  12. .sub-menu li > a span {
  13. color: #797979;
  14. text-shadow: 1px 1px 0px rgba(255,255,255, .2);
  15. background: transparent;
  16. border: 1px solid #c9c9c9;
  17. -webkit-box-shadow: none;
  18. -moz-box-shadow: none;
  19. box-shadow: none;
  20. }
  21. .sub-menu em {
  22. position: absolute;
  23. top: 0;
  24. left: 0;
  25. margin-left: 14px;
  26. color: #a6a6a6;
  27. font: normal 10px/32px Arial, sans-serif;
  28. }

第五步:定义鼠标悬浮和菜单激活时状态样式

当鼠标悬浮和菜单激活时改变 背景为绿色。

  1. accordion > li:hover > a,
  2. .accordion > li:target > a {
  3. color: #3e5706;
  4. text-shadow: 1px 1px 1px rgba(255,255,255, .2);
  5. background: #a5cd4e;
  6. background: -moz-linear-gradient(top, #a5cd4e 0%, #6b8f1a 100%);
  7. background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,#a5cd4e), color-stop(100%,#6b8f1a));
  8. background: -webkit-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
  9. background: -o-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
  10. background: -ms-linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
  11. background: linear-gradient(top, #a5cd4e 0%,#6b8f1a 100%);
  12. }
  13. .accordion > li:hover > a span,
  14. .accordion > li:target > a span {
  15. color: #fdfdfd;
  16. text-shadow: 0px 1px 0px rgba(0,0,0, .35);
  17. background: #3e5706;
  18. }
  19. .sub-menu li:hover a { background: #efefef; }

第六步:控制子菜单的显示与隐藏

为了隐藏子菜单,我们需要定义子菜单的高度为 0px。当点击父菜单时,为子菜单添加下滑显示的动态效果。为了实现下滑的效果,需要指定子菜单固定的高度。因 为这个教程中子菜单有三个 link,所以这里指定了 98px。如果你想加更多的子菜单就需要修改 height 为所有子菜单的高度和,当然如果你想要让它自 动变化,可以给高度赋值 100%,但是这样下滑的动画效果就没有了。

  1. .accordion li > .sub-menu {
  2. height: 0;
  3. overflow: hidden;
  4. -webkit-transition: all .2s ease-in-out;
  5. -moz-transition: all .2s ease-in-out;
  6. -o-transition: all .2s ease-in-out;
  7. -ms-transition: all .2s ease-in-out;
  8. transition: all .2s ease-in-out;
  9. }
  10. .accordion li:target > .sub-menu {
  11. height: 98px;
  12. }

这样子就可以了,大家可以点击演示地址查看效果。

给TA打赏
共{{data.count}}人
人已打赏
前端学习

原生态JS的方法调用CLASS元素标签

2024-10-29 14:30:06

前端学习

Jquery实现页面下拉滚动加载内容

2024-10-30 14:09:23

下载说明

  • 1、微码盒所提供的压缩包若无特别说明,解压密码均为weimahe.com
  • 2、下载后文件若为压缩包格式,请安装7Z软件或者其它压缩软件进行解压;
  • 3、文件比较大的时候,建议使用下载工具进行下载,浏览器下载有时候会自动中断,导致下载错误;
  • 4、资源可能会由于内容问题被和谐,导致下载链接不可用,遇到此问题,请到文章页面进行反馈,以便微码盒及时进行更新;
  • 5、其他下载问题请自行搜索教程,这里不一一讲解。

站长声明

本站大部分下载资源收集于网络,只做学习和交流使用,版权归原作者所有;若为付费资源,请在下载后24小时之内自觉删除;若作商业用途,请到原网站购买;由于未及时购买和付费发生的侵权行为,与本站无关。本站发布的内容若侵犯到您的权益,请联系本站删除,我们将及时处理!
0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
有新私信 私信列表
搜索