首页
关于我们
网站建设
经典案例
网络推广
技术中心
建站指导
联系我们
网站套餐 Package
最新推荐 Recommended  
  您现在的位置: 天诚世纪 >> 技术中心 >> 网页设计 >> WEB标准 >> 正文
li标签的间距问题及书写最佳方式
作者:天诚世纪 更新时间:2009-8-12 21:03:47 来源:天诚世纪
    

新建一个简单的HTML测试文件,下面来测试ul li标签

以下为引用的内容:
<ul> 
<li><a href="#">菜单一</a></li> 
<li><a href="#">菜单一</a></li> 
<li><a href="#">菜单一</a></li> 
<li><a href="#">菜单一</a></li> 
<li><a href="#">菜单一</a></li> 
<li><a href="#">菜单一</a></li> 
</ul> 
<ul>
<li><a href="#">菜单一</a></li>
<li><a href="#">菜单一</a></li>
<li><a href="#">菜单一</a></li>
<li><a href="#">菜单一</a></li>
<li><a href="#">菜单一</a></li>
<li><a href="#">菜单一</a></li>
</ul>

测试一、定义css为如下代码,效果如下

以下为引用的内容:
view plaincopy to clipboardprint?
body{font-size:12px;margin:0}  
ul{list-style:none;margin:0;padding:0;width:120px;}  
ul li{background:green;height:20px;}  
ul li a{color:#fff;padding:0 0 0 10px;} 
body{font-size:12px;margin:0}
ul{list-style:none;margin:0;padding:0;width:120px;}
ul li{background:green;height:20px;}
ul li a{color:#fff;padding:0 0 0 10px;}

发现在IE5和IE5.5下左边都产生了空白,并且在IE5下,LI之间的行距产生空白,如下图 中国.站.长站

天诚世纪 

测试二、定义css为如下代码

以下为引用的内容:
view plaincopy to clipboardprint?
body{font-size:12px;margin:0}  
ul{list-style:none;margin:0;padding:0;}  
ul li{background:green;height:20px;width:120px;}  
ul li a{color:#fff;padding:0 0 0 10px;} 
body{font-size:12px;margin:0}
ul{list-style:none;margin:0;padding:0;}
ul li{background:green;height:20px;width:120px;}
ul li a{color:#fff;padding:0 0 0 10px;}

和测试一相比,只是将width:120px;从ul的定义放置到li的定义,解决了IE5和IE5.5左边产生空白的问题,而IE5的li之间的间距还是有。如下图

天诚世纪 

测试三、定义css为如下代码

以下为引用的内容:
body{font-size:12px;margin:0}
ul{list-style:none;margin:0;padding:0;}
ul li{background:green;height:20px;width:120px;vertical-align: bottom;}
ul li a{color:#fff;padding:0 0 0 10px;}

和测试二比较,在li的定义中加上vertical-align: bottom;ie5下正常,li之间的空白行距消失了,取得各个浏览器的效果一样,如下图

天诚世纪 

总结:

1、解决li在IE5下产生空白行距的方法:如果li定义了宽度,那么需要在li里面再定义vertical-align: bottom;

2、宽度最好不要定义在UL,定义在LI或者UL外层的DIV里面

3、书写LI的最佳方式,li里面要书写高度和宽度,以及vertical-align: bottom;(for ie5/win bug),或者在ul外面加上一层div,并定义宽度,那么在li里面不用定义宽度和vertical-align: bottom;,也显示正常(IE5下不会产生空白行距),不过高度还是要定义一下的。

本文链接:http://www.tc-21.com/ITCenter/200908/20090812210347.html

  • 上一篇文章:
  • 下一篇文章:
  •   更多关于WEB标准的新闻
      相关文章
    DIV与TABLE的区别
    浏览器不能正常解析CSS代码的解决
    HTML与javascript中常用编码浅析
    用CSS3 实现未来的Web
    DIV+CSS网页布局及网站设计常犯错误
    HTML5与HTML4的区别
    CSS布局实例:上中下三行 中间自适应
    CSS常用技巧介绍