来源:自学PHP网 时间:2015-04-14 14:50 作者: 阅读:次
[导读] 如何用CSS制作横向菜单,鼠标经过变色 并显示下拉菜单...本篇是转来的我觉得写得很详细,而且简洁..以前我虽然达到了目的但是好像思路不是很好...只要有父级对象,无论父级是position...
如何用CSS制作横向菜单,鼠标经过变色 并显示下拉菜单...
本篇是转来的我觉得写得很详细,而且简洁..以前我虽然达到了目的但是好像思路不是很好... 只要有父级对象,无论父级是position:relative或poaition:absolute,子级元素都按父级元素来定位 第一步:建立一个无序列表 我们先建立一个无序列表,来建立菜单的结构。代码是: <ul> <li><a href="1">首页</a></li> <li><a href="2">产品介绍</a></li> <li><a href="3">服务介绍</a></li> <li><a href="4">技术支持</a></li> <li><a href="5">立刻购买</a></li> <li><a href="6">联系我们</a></li> </ul> 第二步:隐藏li的默认样式 因为看起来不是很好看,菜单通常都不需要li默认的圆点,我们给UL定义一个样式来消除这些圆点。 当然,为了更好的控制整个菜单,我们把菜单放在一个div里。页面代码变成: <div class="test"> <ul> <li><a href="1">首页</a></li> <li><a href="2">产品介绍</a></li> <li><a href="3">服务介绍</a></li> <li><a href="4">技术支持</a></li> <li><a href="5">立刻购买</a></li> <li><a href="6">联系我们</a></li> </ul> </div> CSS定义为: .test ul{list-style:none;} 说明:“.test ul”表示我要定义的样式将作用在test的层里的ul标签上。 第三步:关键的浮动 这里是菜单变成横向的关键,我们给li元素加上一个“float:left;”属性,让每个li浮动在前面一个li的左面。 CSS定义为: .test li{float:left;} 菜单变横向了。就这么简单!下面需要做的就是优化细节了。 第四步:调整宽度 菜单都挤在一起不好看怎么办?我们来调节li的宽度。 在CSS中添加定义width:100px指定一个li的宽度是100px,当然你可以根据你的需要调整数值: .test li{float:left;width:100px;} 如果我们同时定义外面div的宽度,li就会根据div的宽度自动换行,例如定义了div宽350px,6个li的总宽度是600px,一行排不下就自动变成两行: .test{width:350px;} 第五步:设置基本链接效果 接下来,我们通过CSS来设置链接的样式,分别定义:link、:visited、:hover的状态 .test a:link{color:#666;background:#CCC;text-decoration:none;} .test a:visited{color:#666;text-decoration:underline;} .test a:hover{color:#FFF; font-weight:bold;text-decoration:underline;background:#F00;} 第六步:将链接以块级元素显示 有朋友问,菜单链接的背景色为什么没有填满整个li的宽度?恩,解决的方法很简单,在a的样式定义中增加display:block,使链接以块级元素显示。 同时我们微调了如下细节: 用text-align:center将菜单文字居中; 用height:30px增加背景的高度; 用margin-left:3px使每个菜单之间空3px距离; 用line-height:30px;定义行高,使链接文字纵向居中; CSS定义象这样: .test a{display:block;text-align:center;height:30px;} .test li{float:left;width:100px;background:#CCC;margin-left:3px;line-height:30px;} 第七步:定义背景图片 我们通常都会在每个链接前加一个小图标,这样导航更清楚。CSS是采用定义li的背景图片来实现的: .test a:link{color:#666;background:url(arrow_off.gif) #CCC no-repeat 5px 12px;text-decoration:none;} .test a:hover{color:#FFF; font-weight:bold;text-decoration:none;background:url(arrow_on.gif) #F00 no-repeat 5px 12px;} 说明:“background:url(arrow_off.gif) #CCC no-repeat 5px 12px;”这句代码是一个CSS缩写,表示背景图片是arrow_off.gif;背景颜色是#CCC;背景图片不重复"no-repeat",背景图片的位置是左边距5px、上边距12px; 默认状态下,图标为arrow.off.gif,当鼠标移动到链接上,图标变为arrow_on.gif 现在css的完整代码是: .test ul{list-style:none;} .test li{float:left;width:100px;background:#CCC;margin-left:3px;line-height:30px;} .test a{display:block;text-align:center;height:30px;} .test a:link{color:#666;background:url(arrow_off.gif) #CCC no-repeat 5px 12px;text-decoration:none;} .test a:visited{color:#666;text-decoration:underline;} .test a:hover{color:#FFF; font-weight:bold;text-decoration:none;background:url(arrow_on.gif) #F00 no-repeat 5px 12px;} 页面的完整代码是: <div class="test"> <ul> <li><a href="1">首页</a></li> <li><a href="2">产品介绍</a></li> <li><a href="3">服务介绍</a></li> <li><a href="4">技术支持</a></li> <li><a href="5">立刻购买</a></li> <li><a href="6">联系我们</a></li> </ul> </div> 好了,主要步骤就是这7步,立刻拷贝和修改代码试试,你也可以用CSS做横向菜单了! ============知识点================ 第八步: #templatemo_menu ul li ul { border:1px solid #ccc; display:none; position:absolute; margin-top:83px;} position:absolute; 这句话表示最底层的ul会以他的父层(他的上一层) li 的位置为自己的开始位置! 摘自 Hurry的专栏 |
自学PHP网专注网站建设学习,PHP程序学习,平面设计学习,以及操作系统学习
京ICP备14009008号-1@版权所有www.zixuephp.com
网站声明:本站所有视频,教程都由网友上传,站长收集和分享给大家学习使用,如由牵扯版权问题请联系站长邮箱904561283@qq.com