欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  web前端

IE6/IE7中li底部4px空隙的Bug

程序员文章站 2023-12-29 20:55:28
...
当li的子元素中有浮动(float)时,IE6/IE7中
  • 元素的下面会产生4px空隙的bug。

    代码如下:

    
    
    • vapour
    • 百度
    • 淘宝
    • 迅雷

    经过测试发现:li的子元素浮动是这个bu*生的必要条件,这个bu*生的充要条件是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的Bugtitle>
    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>vapourdiv>li>
    li>div>百度div>li>
    li>div>淘宝div>li>
    li>div>迅雷div>li>
    ul>
    hr />
    ul class="list v-top">
    li>div>vapourdiv>li>
    li>div>百度div>li>
    li>div>淘宝div>li>
    li>div>迅雷div>li>
    
    
    • vapour
    • 百度
    • 淘宝
    • 迅雷

    • vapour
    • 百度
    • 淘宝
    • 迅雷
  • 上一篇:

    下一篇: