当li的子元素中有浮动(float)时,IE6/IE7中<li>元素的下面会产生4px空隙的bug。
代码如下:
<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>
<html> <head> <meta 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>
更多专业前端知识,请上 【猿2048】www.mk2048.com