当li的子元素中有浮动(float)时,IE6/IE7中<li>元素的下面会产生4px空隙的bug。

XHTML

<ul class="list">
<li><div>vapour</div></li>
<li><div>百度</div></li>
<li><div>淘宝</div></li>
<li><div>迅雷</div></li>
</ul>

经过测试发现:li的子元素浮动是这个bug产生的必要条件,这个bug产生的充要条件是li的子元素浮动并且li设置了以下CSS属性之一:width、height、zoom、padding-top、padding-bottom、margin-top、margin-bottom。

知道了这个bug的产生条件,所以解决方法也就有了:

  
     方法1  
     #list div设置clear:left|both,这时#list li不能设置width、height、zoom。  
     方法2  
     #list li设置float:left,这时#list li可以设置width、height、zoom。  
     #list li设置clear:left|both,这时#list li不能设置width、height、zoom。  
     方法3

IE6/IE7的这个Bug可以通过给li中的div设置vertical-align:top|middle|bottom解决。太怪异了,只要加上vertical-align的值是三者之一即可。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>IE6/IE7中li底部3px的Bug</title>
<style type="text/css">
ul { margin: 0; padding: 0; list-style: none; }
hr { clear: both; }
.list li { width: 420px; }
.list div { float: left; width: 400px; height: 24px; background: red; }
.v-top div { vertical-align: top; }
.v-middle div { vertical-align: middle; }
.v-bottom div { vertical-align: bottom; }
</style>
</head>
<body>
<ul class="list">
<li><div>vapour</div></li>
<li><div>百度</div></li>
<li><div>淘宝</div></li>
<li><div>迅雷</div></li>
</ul>
<hr />
<ul class="list v-top">
<li><div>vapour</div></li>
<li><div>百度</div></li>
<li><div>淘宝</div></li>
<li><div>迅雷</div></li>
</ul>
<hr />
<ul class="list v-middle">
<li><div>vapour</div></li>
<li><div>百度</div></li>
<li><div>淘宝</div></li>
<li><div>迅雷</div></li>
</ul>
<hr />
<ul class="list v-bottom">
<li><div>vapour</div></li>
<li><div>百度</div></li>
<li><div>淘宝</div></li>
<li><div>迅雷</div></li>
</ul>
</body>
</html>

最新文章

  1. [LintCode] LRU Cache 缓存器
  2. iOS开发——高级技术&amp;PassBook服务
  3. iOS开发 - AVPlayer实现流音频边播边存
  4. php中mysql操作的buffer知识
  5. CSS 学习质料
  6. 获取本机IP非127.0.0.1
  7. hihoCoder 1039字符消除 (字符串处理)
  8. Swift中元组(Tuples),结构体(Struct),枚举(Enums)之间的区别
  9. POJ 1664 把苹果
  10. [SQL]死锁处理语句
  11. Jira 6.0.5环境搭建
  12. .NET架构师
  13. LCA-倍增法(在线)O(nlogn)-O(logn)
  14. Hadoop日志以及日志的格式和命名组成
  15. __call PHP伪重载方法
  16. 利用野草weedcmsuseragent盲注漏洞拿shell
  17. daterangepicker双日历插件的使用
  18. Error: map 不是模板
  19. JVM家族史考【转】
  20. mysql的安装教程-【linux】

热门文章

  1. 服务器控件HyperLink的NavigateUrl绑定传参问题
  2. Redis 数据备份与恢复
  3. QTextEdit 总结
  4. ASP.NET MVC and jqGrid 学习笔记 1-基本配置
  5. 在SSIS 的 64 位版本中不支持 Excel 连接管理器
  6. java.lang.IllegalStateException
  7. Jsonp post 跨域方案
  8. tomcat初识
  9. ORA-01034: ORACLE not available
  10. okhttputils开源库的混淆配置(Eclipse)