IE6/IE7中li底部3px的Bug
2012-12-11 13:36
190 查看
当li的子元素中有浮动(float)时,IE6/IE7中li会产生3px空隙的bug的。
XHTML
<ul id="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
特别感谢 meimei 的指教,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>
出自:http://jnerish.blog.163.com/blog/static/8805768820103214842564/
XHTML
<ul id="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
特别感谢 meimei 的指教,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>
出自:http://jnerish.blog.163.com/blog/static/8805768820103214842564/
相关文章推荐
- IE6/IE7中li底部4px空隙的Bug
- IE6/IE7中li底部4px的Bug
- IE6、IE7中li底部3px间距BUG
- IE6|IE7中li底部3px间距BUG
- IE6/IE7中li底部4px的Bug
- IE6/IE7中li底部4px空隙的Bug
- 【IE6的疯狂之九】li在IE中底部空行的BUG
- 【IE6的疯狂之六】li在IE中底部3像素的BUG(增加浮动解决问题)
- li在IE中底部空行的BUG
- li margin-bottom在IE6,7中底部3像素的BUG
- 【IE6的疯狂之九】li在IE中底部空行的BUG
- IE7常见bug: <li>下边的3px bug
- li出现间距,IE6/IE7 bug的解决方法
- li ie6/7 3px bug
- IE6/7的Bug:纵向排列的li中加浮动元素产生向下3px的空隙
- 【IE6的疯狂之九】li在IE中底部空行的BUG
- IE6 | IE7 li底部多出几像素bug
- li下3px BUG
- CSS 列表 li 底部空行Bug
- IE6 IE7 hasLayout bug之li间的3px垂直间距