浏览器CSS兼容问题汇总及解决

由于公司项目要求兼容到IE6,这之中遇到不少CSS兼容性问题,所以就在博客汇总下来,以后在项目中遇到新的兼容性问题,也会在这里更新。

1.IE6下height属性会失效

问题描述:在IE6下,即使块级元素设置了高度,但若元素内部的内容超出设置高度,内部内容会把该块级元素高度撑开,height失效。

解决方法:对该块级元素设置overflow:hidden;

2.div存在最小高度

问题描述:在IE6下,块级元素会存在大概是13px默认最小高度,即使是空的div标签或者height属性设置比13px小,也无济于事,这是因为IE6会默认font-size:13px;,即使是空div,也会被撑开,呈现13px的最小高度。

解决方法:设置font-size:0;或者overflow:hidden;

3.IE6下png图片背景不透明

问题描述:在IE7下,png图片背景会呈现灰色,而不是透明。

问题解决:解决方法有多种,我只列出我常用的两种:

     1.用插件解决,插件地址及调用方法如下所示:

<!--[if IE 6]>
<script src="http://img3.job1001.com/js/png.min.js" ></script>
<script>
DD_belatedPNG.fix(‘.head img,.nav_phone img,.search,.qq img‘);
</script>
<![endif]-->

       2.将图片保存成gif格式

4.IE6下设置了position:absolute;的元素不显示

问题描述:IE6下,设置了position:absolute;的元素有可能不显示,原因未明。

问题解决:在该元素后面加个空的div标签,<div></div>

5.IE6下float:right;的元素会换行

问题描述:IE6下,同一行设置若干元素float:left;后若有元素设置float:right;,该元素会换行。

问题解决:foat:right;的元素放置在最前面

6.IE6下,line-height失效

问题描述:IE6下,当文字和img、input、textarea、select、等元素在同一个容器中的时候,line-height属性失效。只有全文字时,line-height属性才有效。

问题解决:在其中一个非文字的对象的样式中增加margin: (容器的line-height - 对象本身的高度)/2px 0;  和 vertical-align:middle;

7.IE6下,hover失效

问题描述:IE6下,hover只对a标签有效

问题解决:用JS代码解决

8.IE6不兼容position:fixed;

问题描述:IE6不支持position:fixed;

问题解决:1.用JS代码解决

      2.用css expression解决(备注:由于css expression极其影响性能,一般情况下不推荐使用),代码如下:

/* IE6 头部固定定位 */
.fixed-top{position:absolute;bottom:auto;
top:expression(eval(document.documentElement.scrollTop));}
/* IE6 右侧固定定位 */
.fixed-right{position:absolute;right:auto;
left:expression(eval(document.documentElement.scrollLeft+document.documentElement.clientWidth-this.offsetWidth)-(parseInt(this.currentStyle.marginLeft, 10)||0)-(parseInt(this.currentStyle.marginRight, 10)||0));}
/* IE6 底部固定定位 */
.fixed-bottom{position:absolute;bottom:auto;
top:expression(eval(document.documentElement.scrollTop+document.documentElement.clientHeight-this.offsetHeight-(parseInt(this.currentStyle.marginTop, 10)||0)-(parseInt(this.currentStyle.marginBottom, 10)||0)));}
/* IE6 左侧固定定位 */
.fixed-left{position:absolute;right:auto;
left:expression(eval(document.documentElement.scrollLeft));}

    这之中可能会出现抖动的情况,所以还需加入

/* 修正IE6抖动bug */
_body{background-image:url(about:blank);background-attachment:fixed;}

9.IE6浮动时会出现双倍margin的bug

问题描述:IE6用float浮动时会出现双倍margin的bug

问题解决:设置属性display:inline;

10.当li中出现2个或以上的浮动时,li之间产生的空白间隙的BUG

问题描述:在IE6、7中,当li中出现2个或以上的浮动时,li之间产生的空白间隙的BUG

问题解决:设置属性vertical-align:top;

11.IE6下的文本溢出BUG

问题描述:如下代码,在IE6下,文本内容会溢出,多出一个“了”,并且注释条数越多,溢出的内容也会随之增多

.test{zoom:1;overflow:hidden;width:500px;}
.box1{float:left;width:100px;}
.box2{float:right;width:400px;}

<div class="test">
    <div class="box1"></div>
    <!-- 注释 -->
    <div class="box2">我就要溢出来了</div>
</div>

问题解决:方法1:删掉box1和box2之间的所有注释

     方法2:取消box1和box2的浮动

后话:除了IE6、7一些自身的bug,更多兼容性问题来自于浏览器本身对一些CSS新属性、选择器或者一些新特性的不支持或者不完全支持,所以,如果项目需要支持低版本浏览器时,请确认所使用CSS特性的浏览器支持程度,推荐登录http://caniuse.com/进行检测。   

时间: 2024-10-10 04:19:23

浏览器CSS兼容问题汇总及解决的相关文章

【转载】各浏览器CSS兼容问题

CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并 整理了一下.对于web2.0的过度,请尽量用xhtml格式写代码,而且DOCTYPE 影响 CSS 处理,作为W3C的标准,一定要加 DOCTYPE声名. CSS技巧 1.div的垂直居中问题 vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了.缺点是要控制内容

浏览器CSS兼容

一.<important 在IE6及FF中的使用>.box1 {width:150px !important;} .box1 {width:250px;} !important是说这个设置有优先级,IE碰到!important不会出错只是忽略他的功能,假如后面又设置了width,IE会以最后设置的 width为准,假如后面再没有其它设置,则会用当前这个值,也就是前面的!important那个值.比如:#test {width: 300px !important }IE与FF都显示300PX.假

各浏览器CSS兼容问题

CSS对浏览器的兼容性有时让人很头疼,或许当你了解当中的技巧跟原理,就会觉得也不是难事,从网上收集了IE7,6与Fireofx的兼容性处理方法并 整理了一下.对于web2.0的过度,请尽量用xhtml格式写代码,而且DOCTYPE 影响 CSS 处理,作为W3C的标准,一定要加 DOCTYPE声名. CSS技巧 1.div的垂直居中问题 vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了.缺点是要控制内容

火狐和IE浏览器的兼容问题汇总

1.window.event code=(navigator.appName="Netscape")?event.which:event.keycode; 2.event.x mx=event.x?event.x:event.pageX(火狐) 3.IE:event.srcElement  ; Firefox:event.target; 4.cursor:hand(仅适用与IE): cursor:pointer;支持所有浏览器 5.innerText与textContent if(na

转载-没有IE就没有伤害!浏览器兼容性问题解决方案汇总

普及:浏览器的兼容性问题,往往是个别浏览器(没错,就是那个与众不同的浏览器)对于一些标准的定义不一致导致的.俗话说:没有IE就没有伤害. 贴士:内容都是自己总结的,不免会出现错误或者bug,欢迎更正和补充,本帖也会不断更新. Normalize.css 不同浏览器的默认样式存在差异,可以使用 Normalize.css 抹平这些差异.当然,你也可以定制属于自己业务的 reset.css <link href="https://cdn.bootcss.com/normalize/7.0.0/

转:【总结】浏览器CSS Hacks汇总,浏览器兼容方式CSS Hacks

[总结]浏览器CSS Hacks汇总 浏览器兼容可以说是前端开发所要面对的第一个挑战,目前我的电脑上已经安装了6种浏览器(基于IE内核的不算,如Maxthon等). CSS hacks利用浏览器的漏洞来隐藏特定浏览器的CSS规则.实现浏览器兼容主要有两种方式条件样式表和CSS Hacks(Selector Hacks.Attribute Hacks).对此根据一些资料汇总了一些CSS Hacks方法.   1.条件样式表 像这样的代码你应该见过: <link rel="stylesheet

IE6 浏览器常见兼容问题 大汇总(23个)

IE6以及各个浏览器常见兼容问题 大汇总 综述:虽然说IE6在2014年4月将被停止支持,但是不得不说的是,IE6的市场并不会随着支持的停止而立刻消散下去,对于WEB前端开发工程师来说,兼容IE6 兼容各个浏览器,依然是不得不面对的工作. 在此总结了常见的浏览器兼容问题,里面也有IE6的常见兼容问题,供大家分享. 如需转载,请注明出处:网易博客-独行冰海:IE6 浏览器常见兼容问题 大汇总 1.<!DOCTYPE HTML>文档类型的声明. 产生条件:IE6浏览器,当我们没有书写这个文档声明的

IE6以及各个浏览器常见兼容问题 大汇总

综述:虽然说IE6在2014年4月将被停止支持,但是不得不说的是,IE6的市场并不会随着支持的停止而立刻消散下去,对于WEB前端开发工程师来说,兼容IE6 兼容各个浏览器,依然是不得不面对的工作.在此总结了常见的浏览器兼容问题,里面也有IE6的常见兼容问题,供大家分享. 如需转载,请注明出处:网易博客-独行冰海:IE6 浏览器常见兼容问题 大汇总1.<!DOCTYPE HTML>文档类型的声明.产生条件:IE6浏览器,当我们没有书写这个文档声明的时候,会触发IE6浏览器的怪异解析现象:解决办法

IE6以及各个浏览器常见兼容问题 大汇总 【转】

IE6以及各个浏览器常见兼容问题 大汇总 综述:虽然说IE6在2014年4月将被停止支持,但是不得不说的是,IE6的市场并不会随着支持的停止而立刻消散下去,对于WEB前端开发工程师来说,兼容IE6 兼容各个浏览器,依然是不得不面对的工作. 在此总结了常见的浏览器兼容问题,里面也有IE6的常见兼容问题,供大家分享. 网易博客-独行冰海:IE6 浏览器常见兼容问题 大汇总 1.<!DOCTYPE HTML>文档类型的声明. 产生条件:IE6浏览器,当我们没有书写这个文档声明的时候,会触发IE6浏览