CSS3制作炫酷的下拉菜单及弹起式选单的实例分享


Posted in HTML / CSS onMay 17, 2016

下拉菜单
先直接来看效果是怎样:
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享

当鼠标移到选单之后,下方会展开并有其它说明内容,我这边是把展开的部份加上图片内容,让它有其它不同的变化。因为这样的动作就像人家庙会时会有舞狮从嘴里丢下贺联一样,所以我才取名为"贺联式选单"。

这样的效果其实只需要 HTML 及 CSS 配合就能做出来了,我们先来看 HTML 的部份:
检视原始码 HTML

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <ul>  
  3.   <li>  
  4.    <a class="t1" href="#">梅干桑   
  5.     <div>自我介绍</div>  
  6.    </a>  
  7.   </li>  
  8.   <li>  
  9.    <a class="t2" href="#">Photoshop   
  10.     <div>上课??!</div>  
  11.    </a>  
  12.   </li>  
  13.   <li>  
  14.    <a class="t3" href="#">Q & A   
  15.     <div>问题讨论</div>  
  16.    </a>  
  17.   </li>  
  18.   <li>  
  19.    <a class="t4" href="#">男丁格尔</a>  
  20.   </li>  
  21.   <li>  
  22.    <a class="t5" href="#">人材   
  23.     <div>丁丁是人材</div>  
  24.    </a>  
  25.   </li>  
  26.   <li>  
  27.    <a class="t6" href="#">格言   
  28.     <div>好话大家说</div>  
  29.    </a>  
  30.   </li>  
  31.   <li>  
  32.    <a class="t7" href="http://www.wowgame.tw">WOWGame</a>  
  33.   </li>  
  34.  </ul>  
  35. </body>  

使用 UL 及 LI 来做选单的项目,每一个 LI 中的 A 连结是我们主要的选单内容,而其 DIV 是更进阶的描述内容,若不需要的话则可以不用加。因为我要让每个选单都有不同的背景图,所以还需要帮 A 连结都加一个独立的 class。

然后,我有 7 个 LI 选单项目,因此我还请梅干帮忙准备了 7 张图片(果然还是要专业的来)。接着就能开始动手写 CSS ?樱?br />检视原始码 CSS

CSS Code复制内容到剪贴板
  1. ul {   
  2.  margin: 0;   
  3.  padding: 0;   
  4.  list-stylenone;   
  5. }   
  6.     
  7. ul li {   
  8.  floatleft;   
  9. }   
  10.     
  11. ul li a {   
  12.  width100px;   
  13.  height50px;   
  14.  displayblock;   
  15.  line-height50px;   
  16.  overflowhidden;   
  17.  text-aligncenter;   
  18.  text-decorationnone;   
  19.  color#fff;   
  20. }   
  21.     
  22. ul li a:hover {   
  23.  height150px;   
  24. }   
  25.     
  26. ul li a div {   
  27.  color#fff;   
  28.  line-height16px;   
  29.  font-weightbold;   
  30.  margin-top73px;   
  31.  padding-top7px;   
  32.  border-top1px dotted #fff;   
  33. }   
  34.     
  35. .t1 { background#08f2d6 url(01.gif); }   
  36. .t2 { background#1209f1 url(02.gif); }   
  37. .t3 { background#a202e2 url(03.gif); }   
  38. .t4 { background#f4e603 url(04.gif); }   
  39. .t5 { background#55df07 url(05.gif); }   
  40. .t6 { background#02a8f3 url(06.gif); }   
  41. .t7 { background#f6025e url(07.gif); }  

这边用到的 CSS 语法都是很基础的,比较需要注意的是我们一开始 A 连结的 height 是 50px,所以超过的部份会因为 overflow 为 hidden 的关系而被隐藏起来;另外,当鼠标移到 A 连结后,再额外订了一个 a:hover { } 来把它的 height 撑高,因此原本看不到的背景部份就会显现出来了。

到这边就整个都完成了,一开始浏览时就只有一排的选单
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享

当鼠标移到选项后就会显示完整的背景内容
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享

且我们的选单一样是有超连结的功能,是不是很有趣呢!如果要让效果更优的话,当然还是需要 JavaScript 的配合才行唷!

弹起式页签选单
一样先直接来看效果是怎样:
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享

跟上一个例子不同的是在此次是鼠标移到选单后会往上升,就象是突然弹起来一样。

这样的效果一样只需要 HTML 及 CSS 就能做出来了,我们先来看 HTML 的部份:

检视原始码 HTML

XML/HTML Code复制内容到剪贴板
  1. <body>  
  2.  <ul id="menu">  
  3.   <li><a href="#" class="home">首页</a></li>  
  4.   <li><a href="#" class="car">购物车</a></li>  
  5.   <li><a href="#" class="good">推荐商品</a></li>  
  6.   <li><a href="#" class="query">订单查询</a></li>  
  7.  </ul>  
  8. </body>  

同样是用 UL 及 LI 来做选单的项目,每一个 LI 中的 A 连结是我们主要的选单内容,且为了让每个选单都有不同的选单图片,所以还帮 A 连结都加一个独立的 class。

接着开始动手写 CSS ?樱?br />检视原始码 CSS

CSS Code复制内容到剪贴板
  1. #menu {   
  2.  margin20px 0 0;   
  3.  padding: 0;   
  4.  height62px;  /* 选单图片的高 */  
  5.  list-stylenone;   
  6.  overflowhidden;   
  7.  width432px;  /* 98 * 4 + 5 * 8 */  
  8.  border-bottom1px solid #ccc;   
  9. }   
  10. #menu li {   
  11.  floatleft;   
  12.  padding: 0 5px;   
  13. }   
  14. #menu li a {   
  15.  displayblock;   
  16.  width98px;  /* 选单图片的宽 */  
  17.  height62px;  /* 选单图片的高 */  
  18.  line-height62px/* ie suck */  
  19.  text-indent: -9999px;   
  20.  margin-top31px/* 需要设定为图片宽/2 */  
  21.  background-repeatno-repeat;   
  22. }   
  23. #menu li a:hover {   
  24.  margin-top1px/* 当鼠标移到选单上时... */  
  25. }   
  26. /* 帮每一个 A 连结都加入不同选单图片 */  
  27. .home {background:url(home.gif);}   
  28. .car {background:url(car.gif);}   
  29. .good {background:url(good.gif);}   
  30. .query {background:url(query.gif);}  

这边要注意的是 A 连结的 margin-top 是选单图片高的一半 - 31px,所以超过的部份就不会显示出来;另外,当鼠标移到 A 连结后,再额外订了一个 a:hover { } 来减少它的 margin-top,因此原本看不到的背景部份就会显现出来了。

到这边就整个都完成了,一开始浏览时就只有一排的选单
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享

当鼠标移到选项后就会弹起来??~
CSS3制作炫酷的下拉菜单及弹起式选单的实例分享

HTML / CSS 相关文章推荐
CSS3 伪类选择器 nth-child()说明
Jul 10 HTML / CSS
非常震撼的纯CSS3人物行走动画
Feb 24 HTML / CSS
图解CSS3制作圆环形进度条的实例教程
May 26 HTML / CSS
css3动画效果小结(推荐)
Jul 25 HTML / CSS
浅谈CSS3 box-sizing 属性 有趣的盒模型
Apr 02 HTML / CSS
html5 兼容IE6结构的实现代码
May 14 HTML / CSS
HTML5 Canvas渐进填充与透明实现图像的Mask效果
Jul 11 HTML / CSS
利用html5的websocket实现websocket聊天室
Dec 12 HTML / CSS
微信端html5页面调用分享接口示例
Mar 14 HTML / CSS
canvas实现扭蛋机动画效果的示例代码
Oct 17 HTML / CSS
浅析HTML5中的download属性使用
Mar 13 HTML / CSS
常用的文件对应的MIME类型汇总
Apr 26 HTML / CSS
CSS3中各种颜色属性的使用教程
May 17 #HTML / CSS
使用CSS3美化HTML表单的技巧演示
May 17 #HTML / CSS
利用CSS3的border-radius绘制太极及爱心图案示例
May 17 #HTML / CSS
CSS3的常见transformation图形变化用法小结
May 13 #HTML / CSS
使用CSS3的font-face字体嵌入样式的方法讲解
May 13 #HTML / CSS
几个CSS3的flex弹性盒模型布局的简单例子演示
May 12 #HTML / CSS
CSS3中的transform属性进行2D和3D变换的基本用法
May 12 #HTML / CSS
You might like
怎样在UNIX系统下安装MySQL
2006/10/09 PHP
php限制上传文件类型并保存上传文件的方法
2015/03/13 PHP
Jquery替换已存在于element上的event的方法
2010/03/09 Javascript
基于jquery的inputlimiter 实现字数限制功能
2010/05/30 Javascript
基于jQuery的message插件实现右下角弹出消息框
2011/01/11 Javascript
IE和Firefox的Javascript兼容性总结[推荐收藏]
2011/10/19 Javascript
JQuery EasyUI 加载两次url的原因分析及解决方案
2014/08/18 Javascript
JS实现控制表格单元格垂直对齐的方法
2015/03/30 Javascript
jQuery实现鼠标悬停显示提示信息窗口的方法
2015/04/30 Javascript
JS折半插入排序算法实例
2015/12/02 Javascript
在Web项目中引入Jquery插件报错的完美解决方案(图解)
2016/09/19 Javascript
bootstrap paginator分页前后台用法示例
2017/06/17 Javascript
vue-resource 拦截器(interceptor)的使用详解
2017/07/04 Javascript
详解vue.js+UEditor集成 [前后端分离项目]
2017/07/07 Javascript
vue生成token保存在客户端localStorage中的方法
2017/10/25 Javascript
Bootstrap Table列宽拖动的方法
2018/08/15 Javascript
vue中axios实现数据交互与跨域问题
2019/05/12 Javascript
使vue实现jQuery调用的两种方法
2019/05/12 jQuery
微信小程序 冒泡事件原理解析
2019/09/27 Javascript
vue 导航菜单刷新状态不消失,显示对应的路由界面操作
2020/08/06 Javascript
React 条件渲染最佳实践小结(7种)
2020/09/27 Javascript
ES6中的Javascript解构的实现
2020/10/30 Javascript
[02:51]2014DOTA2国际邀请赛 IG战队官方纪录片
2014/07/21 DOTA
JSON Web Tokens的实现原理
2017/04/02 Python
详解python的webrtc库实现语音端点检测
2017/05/31 Python
Python mutiprocessing多线程池pool操作示例
2019/01/30 Python
python爬虫 基于requests模块的get请求实现详解
2019/08/20 Python
如何在 Django 模板中输出 &quot;{{&quot;
2020/01/24 Python
CSS3 calc()会计算属性详解
2018/02/27 HTML / CSS
世界上最大的售后摩托车零配件超市:J&P Cycles
2017/12/08 全球购物
Dr. Martens马汀博士法国官网:马丁靴鼻祖
2020/01/15 全球购物
初级软件工程师面试题 Junior Software Engineer Interview
2015/02/15 面试题
中学生校园广播稿
2014/01/16 职场文书
小学学雷锋活动总结
2014/04/25 职场文书
经典团队口号大全
2014/06/21 职场文书
居委会工作总结2015
2015/05/18 职场文书