<!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>无标题文档</title>
<style type="text/css">
body,div{
 margin:0;
 padding:0;
}
#div1{
    width:200px;
 height:200px;
 background:#900;
 margin:20px 0 0 20px;
 float:left;
}
#div2{
 width:300px;
 height:200px;
 background:#009;
 margin:20px 0 0 20px;
 float:left;
}
</style>
</head>

<body>
<div id="div1">
</div>
<div id="div2">
</div>
</body>
</html>

上面这段代码,在IE6和FF中的显示结果分别如下图所示:

IE6:

FF:

可以看到,在IE6中显示的红色区域的左边距实际为40px,是CSS代码中设置的20px的两倍,这是IE6的双边距BUG。当满足下面这三个条件时,就会出现这个BUG:

1、要为块状元素;

2、要左侧浮动;

3、要有左外边距(margin-left)

解决这个BUG,只需在相应的块状元素的CSS属性中加入“display:inline;”。

出现双边距的条件是当浮动元素的浮动方向和margin的方向一致时才会出现。也就是说,并不是只有块状元素左浮动,且具有左外边距时才有这个BUG,当一个盒子右浮动的同时有一个向右的margin-right的时候,IE6也会把margin-right解析为原来的2倍。当有多个同行元素都浮动了,而且都有同方向的margin,则只有最靠近浮动方向的元素有双边距bug。

解决这个bug有两个方法:
1.给float的元素添加一个display:inline
2.给ie6写一个hack,其值是正常值的一半,即_margin-right:10px;这个方法不推荐,因为要加hack写法,而这个是要尽量避免写的。但是这个正好能够说明这个bug的真实存在。

本来以为,将display设置为inline后,就改变了BUG产生的条件之一,即必须是块状元素。但是后来又看到了下面这段话:“熟悉规则的人知道浮动元素自动设置为”block”元素,而不管他们之前是什么。这说明浮动元素上的{display: inline;}会被忽略,事实上所有的浏览器没有呈现任何改变,包括IE。但是,它不知何故让IE停止将浮动元素的边界翻倍。”

最新文章

  1. 轻量级ORM框架——第二篇:Dapper中的一些复杂操作和inner join应该注意的坑
  2. HTML 表
  3. mozilla firefox 安装flash player
  4. DateTime.Now.ToString() 用法
  5. Google140道面试题
  6. iOS开发UI篇—Quartz2D使用(图片剪切)
  7. linux配置的问题
  8. DbUtils使用时抛出Cannot get a connection
  9. leetcode 6
  10. 自己写一个jQuery垂直滚动栏插件(panel)
  11. [Hadoop源码解读](一)MapReduce篇之InputFormat
  12. 08_linux下安装chrome
  13. 【莫比乌斯反演】BZOJ2820 YY的GCD
  14. mybatis的xml中sql语句中in的写法(迭代遍历)
  15. boost::bind 介绍
  16. TF:TF分类问题之MNIST手写50000数据集实现87.4%准确率识别:SGD法+softmax法+cross_entropy法—Jason niu
  17. Bug03_SSM整合_mybatis result maps collection already contains value...
  18. 【BZOJ3240】【UOJ#124】【NOI2013】矩阵游戏
  19. linux读书笔记(5章)
  20. yii中缓存(cache)详解

热门文章

  1. 我的web前端修炼之路从此开始
  2. 【Hadoop学习】HDFS中的集中化缓存管理
  3. 自动帮助创建android资源xml文件的网站
  4. homework09-虐心的现程设终于要告一段落了
  5. HDU 5805 NanoApe Loves Sequence (模拟)
  6. UVALive 7324 ASCII Addition (模拟)
  7. 应用反射写的tostring方法
  8. mysql查询数据库大小和表
  9. [转]Oracle 操作字符串的函数
  10. JFinal搭建时,提示着不到contextpath