1、双倍边距

如下图所示,一个样式里面既设定了“float:left;”又有“margin-left:100px;”的情况,就呈现了双倍情况。如外边距设置为100px, 而左侧则呈现出200px,解决它的方法是在浮动元素上加上display:inline;的样式,或者尽量少用这种形式,这样就可避免双倍边距bug。

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.box{
background: rosybrown;
width:100px;
height:200px;
float: left;
margin-left: 100px;
display: inline;
}
</style>
</head>
<body>
<div class="box">
</div>
</body>
</html>

显示的结果如下:

添加display:inline                                                                      不添加display:inline时

                                 

2、3像素问题

问题:2列布局。左列固定,右列液态

当使用float浮动容器后,在IE6下会产生3px的空隙,有意思的是右侧容器没设置高度时3px在右侧容器内部,当设定高度后又跑到容器的左侧了。解决方法有几种,对于网上非常流行的给右侧div增加margin-right: -3px,大大增加了布局的复杂度并且如果父div有设置浮动的话就会失效,解决方法:可以同样给右侧设置左浮动。(还有其他方法)

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.left{
background: red;
width:100px;
height:100px;
float:left;
}
.right{
width:100px;
height:100px;
background: green;
}
</style>
</head>
<body>
<div class="left"></div>
<div class="right"></div>
</body>
</html>

在FF下:两个div内容重合了                                                        ie6下:出现了中间3px的缝隙

                        

设置right部分float:left之后:

FF下

ie6下

3、超链接访问过后hover样式就不出现的问题

被点击访问过的超链接样式不在具有hover和active了,很多人应该都遇到过这个问题,解决方法是改变CSS属性的排列顺序: L-V-H-A(一般现在只用hover就可以了)
        a:link {color:blue; text-decoration:none;}
        a:visited {color:aqua;text-decoration:none;}
        a:hover {color:green; text-decoration:underline;}
        a:active {color:red;}

4、li在ie中底部3像素的bug

IE6还有奇数宽高的bug,解决方案就是将外部相对定位的div宽度改成偶数。

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.waibu{
background: #4386d4;
color:#000;
width:401px;
height:200px;
position: relative; }
.libu{
background: red;
color:#ffffff;
width:100px;
height:100px;
top:0px;
right:0px;
position: absolute;
} </style>
</head>
<body> <div class="waibu">
background: #4386d4;
color:#ffffff;
width:400px;
height:200px;
<div class="libu">
background: red;
color:#ffffff;
width:100px;
height:100px;
vertical-align: middle;
</div>
</div> </body>
</html>
 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.waibu{
background: #4386d4;
color:#000;
width:401px;
height:200px;
position: relative; }
.libu{
background: red;
color:#ffffff;
width:100px;
height:100px;
top:0px;
right:0px;
position: absolute;
} </style>
</head>
<body> <div class="waibu">
background: #4386d4;
color:#ffffff;
width:400px;
height:200px;
<div class="libu">
background: red;
color:#ffffff;
width:100px;
height:100px;
vertical-align: middle;
</div>
</div> </body>
</html>

在FF中:                                                                                                                                            ie6下:

                              

将外层的宽度改为400偶数后,ie6下的效果如图所示:

5、IE6下为什么图片下方有空隙产生

解决这个BUG的方法也有很多,可以是改变html的排版,或者定义img 为display:block
或者定义vertical-align属性值为vertical-align:top | bottom |middle |text-bottom
还可以设置父容器的字体大小为零,font-size:0

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
body{
background:tan;
}
img{ }
.main{
width:200px;
height:400px;
border:1px solid yellow;
}
</style>
</head>
<body> </div>
<div class="main">
<img src="../img/11.jpg">
<img src="../img/11.jpg">
</div>
</body>
</html>

如图所示:

当添加display:block后,效果如下:

6、ie6下空标签高度问题

一个空div如果高度设置为0到19px,IE6下高度默认始终19px。
例如:.text { background-color:#f00; height:0px; /*给定任何小于20px的高度 */}   <div></div>

如果不让它默认为19PX。而是0PX的话
解决方法有3种:
1.css里面加上overflow:hidden;
2.div里面加上注释;<div><!– –></div>
3.css里面加上line-height:0px; 然后div里面加上&nbsp;<div>&nbsp;</div>

7、样式中文注释后引发失效

这是ie6 出现的奇怪现象。这是由于css 和html 的编码不同所引致。

满足下面条件就会引起 注释下面的样式不起作用:
1. css有中文注释
2. css为ANSI编码
3. html为utf-8编码

解决方法:
1. 去掉中文注释,用英文注释
2. 统一css 和 html 的编码(建议采用第二种解决方法)

ps: css为uft-8  html 为ANSI 不会出现失效的情况。

8、ie6下的圆角

IE6不支持CSS3的圆角,性价比最高的解决方法就是用图片圆角来替代,或者放弃IE6的圆角。

例如如下代码:

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
.main{
width:100px;
height:50px;
background: red;
border-radius: 10px;;
}
</style>
</head>
<body>
</div>
<div class="main"> </div>
</body>
</html>

在ie6下的结果为:                                                    ie9下:
                                

9、最小高度

ie6不支持min-height属性,但它却认为height就是最小高度。解决方法:使用ie6不支持但其余浏览器支持的属性!important。

例:#container {min-height:200px; height:auto !important; height:100px;}

10、100% 高度

在IE6下,如果要给元素定义100%高度,必须要明确定义它的父级元素的高度,如果你需要给元素定义满屏的高度,就得先给html和body定义height:100%;

如下代码所示:前为不加body高度时的效果,后为加上body高度时的效果:

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style>
body{
height:100%;
}
.main{
width:50px;
background: red;
height:100%;
}
</style>
</head>
<body>
</div>
<div class="main"> </div>
</body>
</html>

效果:

设置父级高度后:

11、躲猫猫bug

在IE6和IE7下,躲猫猫bug是一个非常恼人的问题。一个撑破了容器的浮动元素,如果在他之后有不浮动的内容,并且有一些定义了:hover的链接,当鼠标移到那些链接上时,在IE6下就会触发躲猫猫。

解决方法很简单:在(那个未浮动的)内容之后添加一个<span style="clear: both;"> </span>
如以下代码:

 <!DOCTYPE html>
<html>
<head>
<title></title>
<style> .main{
width:150px;
height:auto;
background: red;
color:#ffffff;
float: left;
}
.tit{
float:left;
}
.main a{
color:green;
clear: both;
}
.main a:hover{
color:cyan;
}
</style>
</head>
<body>
</div>
<div class="main">
<p class="tit">
做前端要有爱<br>
做前端要有爱<br>
做前端要有爱<br>
做前端要有爱<br>
做前端要有爱<br>
</p>
<a href="#">你猜你猜你猜你猜</a>
</div>
</body>
</html>

没有添加clear:both时:                                                               添加clear:both之后

                            

12、终极方法:条件注释

<!--[if lte IE 6]> 这段文字仅显示在 IE6及IE6以下版本。 <![endif]-->

<!--[if gte IE 6]> 这段文字仅显示在 IE6及IE6以上版本。 <![endif]-->

<!--[if gt IE 6]> 这段文字仅显示在 IE6以上版本(不包含IE6)。 <![endif]-->

<!--[if IE 5.5]> 这段文字仅显示在 IE5.5。 <![endif]-->

<!--在 IE6及IE6以下版本中加载css-->

<!--[if lte IE 6]> <link type="text/css" rel="stylesheet" href="css/ie6.css"/><![endif]-->

缺点是在IE浏览器下可能会增加额外的HTTP请求数。

---恢复内容结束---

IE6下css常见bug处理的更多相关文章

  1. IE6中CSS常见BUG全集及解决方案——摘自网友

    IE6中CSS常见BUG全集及解决方案 IE6双倍边距bug 当页面内有多个连续浮动时,如本页的图标列表是采用左浮动,此时设置li的左侧margin值时,在最左侧呈现双倍情况.如外边距设置为10px, ...

  2. IE6下CSS常见兼容性问题及解决方案

    1. 在IE6元素浮动,如果宽度需要内容撑开,就给里面的块元素加浮动. 2. IE6下最小高度问题:在IE6下元素高度小于19px的时候,会被当作19px处理.解决方案:给元素加 overflow:h ...

  3. jquery博客收集的IE6中CSS常见BUG全集及解决方案

    今天的样式调的纠结,一会这边一会那么把jquery博客折腾的头大,浏览器兼容性.晚上闲着收集一些常见IE6中的BUG 3像素问题及解决办法 当使用float浮动容器后,在IE6下会产生3px的空隙,有 ...

  4. IE6的那些css常见bug(汇总)

    IE6的那些css常见bug(汇总) 我的微博终于在前几天建立了 虽说很早之前就知道博客园这个地方 但怕自己不能坚持去写一些东西一直没有建.这几天 我做了这个决定 把我的博客建起来 每周发一些看到的, ...

  5. 我的第一篇文章 —— IE6的那些css常见bug(汇总)

    我的微博终于在前几天建立了 虽说很早之前就知道博客园这个地方 但怕自己不能坚持去写一些东西一直没有建.这几天 我做了这个决定 把我的博客建起来 每周发一些看到的,听到了一些前端知识或者前沿技术. 另外 ...

  6. IE6对CSS支持Bug收集

    1.IE6双外边距 在IE6下,如果对元素设置了浮动,同时又设置了margin-left或者margin-right,margin值会加倍. 例如,设置margin-left:10px在IE6下会显示 ...

  7. IE6中的常见BUG与相应的解决办法

    开发前端的同学一定都知道,IE6是兼容BUG最多的浏览器,它不支持PNG alpha通道暂且不论.其文档的解析理解规范也引起了诸多恼人的BUG,有时甚至让人感到绝望.本文主要讲解一些比较容易遇到的IE ...

  8. CSS常见BUG

    CSS Hack IE条件注释: 所有IE:<!--[if IE]> css code <![endif]--> IE6以上:<!--[if gt IE 6]> c ...

  9. js在ie6下的一个bug—未结束标签的错误

    在IE6下,如果在body标签没结束前,用代码获取body对象就会出现错误.如: <html> <head> <script type="text/javasc ...

随机推荐

  1. [P1580] yyy loves Easter_Egg I

    Link: P1580 传送门 Solution: 拿来练练字符串的读入: 1.$gets()$相当于$c++$中的$getline()$,但返回值为指针!(无数据时为NULL) (都读入换行符,并将 ...

  2. [UOJ300]吉夫特

    直接上lucas定理,可以得到$\binom nm=1$等价于$m$是$n$的子集(二进制) 因为数字两两不同,所以设$f_i$表示以$i$开头的满足要求的序列有多少个,转移就是$f_i\gets f ...

  3. 【kmp算法】poj2185 Milking Grid

    先对每行求出所有可能的循环节长度(不需要整除). 然后取在所有行中都出现了的,且最小的长度为宽. 然后将每一行看作字符,对所有行求next数组,将n-next[n](对这些行来说最小的循环节长度)作为 ...

  4. 【动态规划】【记忆化搜索】【搜索】CODEVS 1262 不要把球传我 2012年CCC加拿大高中生信息学奥赛

    可以暴力递归求解,应该不会TLE,但是我们考虑记忆化优化. 设f(i,j)表示第i个数为j时的方案数. f(i,j)=f(1,j-1)+f(2,j-1)+……+f(i-1,j-1) (4>=j& ...

  5. 5.7(java学习笔记)Vector、Enumeration

    一.Vector Vector类实现一个可扩展的数组对象.与数组一样,它包含可以使用整数索引访问. 它的基本操作方法add(int index, E element),get(int index),i ...

  6. python的turtle模块画折线图

    代码如下: import turtle yValues = [10.0,7.4,6.4,5.3,4.4,3.7,2.6] def main(): t = turtle.Turtle() t.hidet ...

  7. 扩展gridview轻松实现冻结行和列(增强型)

    上一篇说过,还可以扩展gridview的分页功能以及实现导出结果为EXCEL/PDF的功能.实现好后应该封装起来,以方便后续的项目简单使用.至于要如何实现,我想不必过多的说了.下面是显示结果和主要的代 ...

  8. CASS 7.1 和 AutoCAD 2006的安装使用

    CAD 2006由于是一个古老的版本,所以在WIN7,WIN10上直接安装的话,一般无法成功.此外,AutoCAD 2006是不分32位64位的,之后的版本都是区分的. 但是,对于我这种几年不用一次C ...

  9. 设置cookie和查找cookie的方法

    1.设置cookie(名称,值,过期时间) function setCookie(key,value,d){ if(d === undefined){ document.cookie = encode ...

  10. 定期访问WebLogic Server返回状态的脚本

    在运维过程中,经常要获悉WebLogic Server的状态以便于主动的维护,本文通过weblogic WLST脚本初步设计了一下 脚本大概为2个,一是WLST的py脚本,getStates.py c ...