在我们这样一个神奇的国度,到了2014年了,居然还是有很多人的电脑上用着XP,安装的是IE6,他们没有想过要升级,我们就得想着兼容他们。。。。

一、 6爷我喝高了,最后一行有重影。那什么是IE6 的3像素bug?

IE7修正了IE6中的一个bug,bug名字就叫做“3像素bug”,即文字溢出bug. 表现形式是ie6浏览器下文字或者图片溢出,莫名其妙的自动复制几个字符。如下图,就自动溢出了一个“下一页”。

二、3像素bug是怎么产生的?

一个容器A包含2两个具有“float”样式的子容器B和C。
第二个容器C的宽度大于父容器A的宽度,或者父容器A宽度减去第二个容器C宽度的值小于3。
在第二个容器前存在注释(这也是为什么此bug也叫做“IE6注释bug”的原因)。

下面是这段代码再现了bug的产生过程,如果用ie6浏览,则在下面 会多出一个“醉”字。

<div style=”width:200px;”>
<div style=”float:left;”></div>
<div style=”float:left;width:200px;”>我是6爷,我没醉</div>
</div>

三、怎样让6爷快速醒酒?ie 6 3像素bug的最佳解决办法:margin-right:-3px;

关于解决办法网上有很多转载,但是我一一试过之后很多都不奏效或者不理想。下面是一段摘录:

1.改变结构,不出现【一个容器包含2两个具有“float”样式的子容器】的结构。
——此解决方案的评论:疯了!因噎废食的做法。
2.减小第二个容器的宽度,使父容器宽度减去第二个容器宽度的值大于3,例如将本文示例中第二个子容器的宽度改为197px。
——此解决方案的评论:在满足页面布局的前提下可以使用。但是当情况比较复杂的时候,可能实施起来比较困难。
3.去掉所有的注释。
——此解决方案的评论:最直接的做法,但是“没有注释的代码”,的确不是一个好的代码写作习惯。
4.修正注释的写法。将 <!– 这里是注释内容 –>写成<!–[if !IE]>这里是注释内容<![endif]–>
——此解决方案的评论:还不错的解决方案,但是并不是每个人都对<!–[if !IE]>这里是注释内容[endif]–>这种注释写法很欣赏。
5.在第二个容器后面加一个或者多个<div style=”clear”></div>来解决。
——此解决方案的评论:另人感觉很不爽的解决方案。但是的确能解决。影响网页效率

这五种方法我都不推荐,根据我的实验最直接的解决问题的方法是在父容器A添加 margin-right:-3px; 一般情况下都可以解决这个问题。

<div style=”width:200px;margin-right:-3px;”>
<div style=”float:left;”></div>
<div style=”float:left;width:200px;”>我是6爷,我没醉</div>
</div>

四、珍爱生命,远离ie6

因为溢出bug产生的根本原因没人可以解释,所以也就没有对应的一劳永逸的办法。要从根本上解决这个问题只有一个办法,就是kill ie6。但是MS微软比我们还着急,可是就是不给力啊。。。。。

转载于:https://www.cnblogs.com/ranzige/p/ie6_3px_problems.html

IE6的3像素神奇bug:缘起与解决方案相关推荐

  1. 如何解决IE6的3像素问题?

    当相邻的两个元素,一个是浮动的,另一个非浮动,那么在IE6 下面将会产生3像素bug. 解决的办法: 给后面的元素,也设置float浮动. 以上就是关于"如何解决IE6的3像素问题?&quo ...

  2. 修复 IE 的文本3像素偏移Bug

    在IE6及更低版本中,当一个浮动元素与一个非浮动元素相邻时,在非浮动元素中,会莫名的为靠近浮动元素的内容添加 3 像素的间隙. 假设在一个容器中,有两个元素: <div id="wra ...

  3. [转]ie6下CSS存在的BUG

    A 双倍MARGIN 設置float的位于行首的元素[如div, ul中的li等],使用margin后,横向margin值会加倍 div { float:left; margin-left:10px; ...

  4. [css] 写出你遇到过IE6/7/8/9的BUG及解决方法

    [css] 写出你遇到过IE6/7/8/9的BUG及解决方法 把以前兼容IE6.7学习的东西搬出来了,还以为不见了.兼容性问题 1.IE6margin双边距问题 2.IE67 li间隙问题 3.图片间 ...

  5. android:ellipsize=end 不起作用,Android应用开发Android TextView关于android:ellipsize=end的一个神奇bug解决方案...

    本文将带你了解Android应用开发Android TextView关于android:ellipsize=end的一个神奇bug解决方案,希望本文对大家学Android有所帮助. 疑惑 今天在开发过 ...

  6. ie6,ie7,ie8,ie9 css bug兼容解决记录

    select {background-color:red\0; /* ie 8/9*/background-color:blue\9\0; /* ie 9*/*background-color:#dd ...

  7. 4、列举你工作中遇到的IE6 BUG,谈谈解决方案

    1.IE6下图片下有空隙产生     解决这个BUG的方法也有很多,可以是改变html的排版,或者设置img 为display:block 或者设置vertical-align 属性为 vertica ...

  8. a标签点击跳转失效--IE6、7的奇葩bug

    一般运用a标签包含img去实现点击图片跳转的功能,这是前端经常要用到的东西. 今天遇到个神奇的bug:如果在img上再包裹一层div,而且div设置了width和height,则图片区域点击时,无任何 ...

  9. IE6不支持min-heigt的bug解决的办法

    今天工作重构页面发现有个关于实现最小高度的问题.用min-height可以解决标准的浏览器的最小高度问题,但是利用ie6不识别!important的bug,而其他浏览器可以识别.我们可以把容器设为.b ...

最新文章

  1. xamp已有mysql端口修改依然启动不_关于xampp启动不了mysql的解决方法
  2. 静态链接库与动态链接库
  3. java中redis存储map集合_使用RedisTemplate存储Map集合的一点注意
  4. Android漫游记(1)---内存映射镜像(memory maps)
  5. bat替换文件中的字符串_JavaScript 中替换字符串的几种方法
  6. (转)Windows Phone7页面导航
  7. oracle11g服务项及其启动顺序
  8. python pop3_Python使用POP3和SMTP协议收发邮件
  9. CRC校验和CRC各种算法
  10. vue 日程表组件_VUE也有自己的日历组件
  11. matlab求随机过程的数学期望,密度函数已知,怎么用matlab求其数学期望和方差?...
  12. 服务器远程桌面连接不上(远程桌面连接服务器之超级VPS管理器)
  13. 最新百度云不限速软件
  14. matlab 层次聚类不均等巨雷,matlab层次聚类
  15. charles 抓 app 请求,设置端口,手动设置手机代理IP 、端口,增加监控的网址,并在手机安装证书防止乱码
  16. 人脸识别接口_人脸识别双模摄像头解析,免费搭配活体检测
  17. 蓝队工具:使用VirusTotal API校验样本
  18. 这7点不去做外汇交易难爆仓
  19. 什么是C语言和C++
  20. 单片机c语言指针作用,单片机C语言教程:C51指针的使用

热门文章

  1. python查询千万级数据_Python批量删除mysql中千万级大量数据
  2. 文献阅读High-throughput sequencing of the transcriptome and chromatin accessibility in the same cell
  3. python中不能使用下标运算的是_下列选项中,不能使用下标运算的是() (3.0分)_学小易找答案...
  4. 超分辨率分析(二)--深度学习方案综述
  5. 纯新手DSP编程--5.31--硬件中断管理
  6. 【数据库原理实验(openGauss)】事务与并发控制
  7. 有趣的检查边界面试题
  8. redis sentinel 哨兵
  9. ssh整合之四单独搭建struts的运行环境
  10. 初探HTML5.x新特性《dialog》标签