如何用DIV+CSS制作横向菜单我们先来看一个菜单的例子,最终效果是:然后我们来详细讲解步骤第一步:建立一个无序列表我们先建立一个无序列表,来建立菜单的结构。代码是:
效果是:第二步:隐藏li的默认样式因为看起来不是很好看,菜单通常都不需要li默认的圆点,我们给UL定义一个样式来消除这些圆点。当然,为了更好的控制整个菜单,我们把菜单放在一个div里。页面代码变成:CSS定义为:.testul{list-style:none;}说明:“.testul”表示我要定义的样式将作用在test的层里的ul标签上。现在的效果是没有圆点了:第三步:关键的浮动这里是菜单变成横向的关键,我们给li元素加上一个“float:left;”属性,让每个li浮动在前面一个li的左面。CSS定义为:.testli{float:left;}效果是:看,菜单变横向了。就这么简单!下面需要做的就是优化细节了。第四步:调整宽度菜单都挤在一起不好看怎么办?我们来调节li的宽度。在CSS中添加定义width:100px,指定一个li的宽度是100px,当然你可以根据你的需要调整数值:.testli{float:left;width:100px;}效果是:如果我们同时定义外面div的宽度,li就会根据div的宽度自动换行,例如定义了div宽350px,6个li的总宽度是600px,一行排不下就自动变成两行:.test{width:350px;}效果是:第五步:设置基本链接效果接下来,我们通过CSS来设置链接的样式,分别定义:link、:visited、:hover的状态.testa:link{color:#666;background:#CCC;text-decoration:none;}.testa:visited{color:#666;text-decoration:underline;}.testa: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定义象这样:.testa{display:block;text-align:center;height:30px;}.testli{float:left;width:100px;background:#CCC;margin-left:3px;line-height:30px;}效果变成:这样就漂亮多了吧。第七步:定义背景图片我们通常都会在每个链接前加一个小图标,这样导航更清楚。CSS是采用定义li的背景图片来实现的:.testa:link{color:#666;background:url(arrow_off.gif)#CCCno-repeat5px12px;text-decoration:none;}.testa:hover{color:#FFF;font-weight:bold;text-decoration:none;background:url(arrow_on.gif)#F00no-repeat5px12px;}说明:“background:url(arrow_off.gif)#CCCno-repeat5px12px;”这句代码是一个CSS缩写,表示背景图片是arrow_off.gif;背景颜色是#CCC;背景图片不重复"no-repeat",背景图片的位置是左边距5px、上边距12px;默认状态下,图标为arrow.off.gif,当鼠标移动到链接上,图标变为arrow_on.gif效果变成:现在css的完整代码是:.testul{list-style:none;}.testli{float:left;width:100px;background:#CCC;margin-left:3px;line-height:30px;}.testa{display:block;text-align:center;height:30px;}.testa:link{color:#666;background:url(arrow_off.gif)#CCCno-repeat5px12px;text-decoration:none;}.testa:visited{color:#666;text-decoration:underline;}.testa:hover{color:#FFF;font-weight:bold;text-decoration:none;background:url(arrow_on.gif)#F00no-repeat5px12px;}页面的完整代码是: