`

(转)整理浏览器对网页的兼容性问题(二)——CSS篇

 
阅读更多

二、            CSS兼容性:

 

1.        CSS中几种浏览器对不同关键字的支持,可进行浏览器兼容性重复定义

!important    可被FireFoxIE7识别

*                   可被IE6IE7识别

_                   可被IE6识别

*+                 可被IE7识别

 

2.        IE专用的条件注释

 

<!--其他浏览器 -->

<link rel="stylesheet" type="text/css" href="css.css" />

 

<!--[if IE 7]>

<!-- 适合于IE7 -->

<link rel="stylesheet" type="text/css" href="ie7.css" />

<![endif]-->

 

<!--[if lte IE 6]>

<!-- 适合于IE6及一下 -->

<link rel="stylesheet" type="text/css" href="ie.css" />

<![endif]-->

 

3.        几个浏览器对实际像素的解释

 

IE/Opera:对象的实际宽度 = (margin-left) + width + (margin-right)

 

Firefox/Mozilla:对象的实际宽度= (margin-left) + (border-left-width) + (padding- left) + width + (padding-right) + (border-right-width) + (margin-right)

 

4.        鼠标手势问题:FireFoxcursor属性不支持hand,但是支持pointerIE两个都支持;所以为了兼容都用pointer

 

5.        FireFox中设置HTML标签的Style属性时,所有位置、宽高和尺寸值必须后跟pxIE也支持此写法,因此统一加px单位。如 Obj.Style.Height = imgObj.Style.Height + ‘px’;

 

6.        FireFox无法解析简写的padding属性设置,如padding 5px 4px 3px 1px;必须改为 padding-top:5px; padding-right:4px; padding-bottom:3px; padding-left:1px0

 

7.        消除ulol等列表的缩进时,样式应写成:list-style:none;margin:0px;padding:0px;其中margin属性对IE有效,padding属性对FireFox有效

 

8.        CSS控制透明:IEfilter:progid:DXImageTransform.Microsoft.Alpha(style=0,opacity=60);                               FireFoxopacity:0.6;

 

9.        CSS控制圆角:IE:不支持圆角;

FireFox: -moz-border-radius:4px;

-moz-border-radius-topleft:4px;

-moz-border-radius-topright:4px;

-moz-border-radius-bottomleft:4px;

-moz-border-radius- bottomright:4px;

 

10.    CSS双线凹凸边框:IEborder:2px outset;

FireFox

-moz-border-top-colors: #d4d0c8 white;

-moz-border-left-colors: #d4d0c8 white;

-moz-border-right-colors:#404040 #808080;

-moz-border-bottom-colors:#404040 #808080;

 

11.    IE支持CSS方法cursor:url()自定义光标样式文件和滚动条颜色风格;FireFox对以上两者均不支持

 

12.    IESelect控件永远处于最上层的bug,且所有CSSSelect控件都不起作用

 

13.    IE支持Form中的Label标签,包括图片和文字内容;FireFox不支持包含图片的Label,点击图片不能让标记 label for RadioCheckBox产生效果

 

14.    FireFox中的TextArea不支持onScroll事件

 

15.    FireFox不支持displayinlineblock

 

16.    FireFoxDiv设置margin-left, margin-rightauto时已经居中, IE中不行

 

17.    FireFoxBody设置text-align, Div需要设置margin: auto(主要是margin-left margin-right) 方可居中

 

18.    对超链接的CSS样式设置最好遵从这样的顺序:L-V-H-A。即

<style type="text/css">
<!-- 
a:link {}
a:visited {}
a:hover {}
a:active {}
-->
</style>

这样可以避免一些访问过后的超链接就不具备hoveractive样式了

 

19.    IE中设置长段落自动换行在CSS中设置word-wrap:break-wordFireFox中使用JS插入&#10;的方法来实现,具体代码如下:

<script type="text/javascript">

/* <![CDATA[ */

function toBreakWord(el, intLen){

var obj=document.getElementById(el);

var strContent=obj.innerHTML;

var strTemp="";

while(strContent.length>intLen){

strTemp+=strContent.substr(0,intLen)+"&#10;";

strContent=strContent.substr(intLen,strContent.length);

}

strTemp+="&#10;"+strContent;

obj.innerHTML=strTemp;

}

if(document.getElementById && !document.all) toBreakWord("div_id", 37);

/* ]]> */

</script>

 

20.    在子容器加了浮动属性后,该容器将不能自动撑开

 

解决方法:在标签结束后下一个标签中加上一个清除浮动的CSS clear:both;

 

21.    浮动后IE6解释外边距为实际边距的双倍

 

解决办法:加上display:inline

 

22.    IE6下图片下方会有空隙

 

解决办法:为img加上display:block或设置vertical-align 属性为vertical-align:top | bottom |middle |text-bottom

 

23.    IE6下两个层中间有空隙

 

解决办法:设置右侧div也同样浮动float:left或者相对IE6定义 margin-right:-3px;

 

24.    LI中内容超过长度后以省略号的显示方法

<style type="text/css">

<!--

li {

width:200px;

white-space:nowrap;

text-overflow:ellipsis;

-o-text-overflow:ellipsis;

overflow: hidden;

}

-->

</style>

 

25.    将元素的高度和行高设为相同值,即可垂直居中文本

<style type="text/css">

<!--

div {

height:30px;

line-height:30px;

}

-->

</style>

 

26.    对齐文本与文本输入框,须在CSS中增加vertical-align:middle;属性设置

<style type="text/css">

<!--

… …

vertical-align:middle;

}

-->

</style>

 

27.    支持WEB标准的浏览器设置了固定高度值就不会像IE6那样被撑开,但是又想设置固定高度又想能够被撑开呢?解决办法是去掉height属性而设置min-height,为了兼容不支持min-heightIE6可以这样定义:

{

height:auto!important;

height:200px;

min-height:200px;

}

 

28.    web标准中IE无法设置滚动条颜色

 

解决办法:在CSS中对body的设置改为对html

<style type="text/css">

<!--

html {

scrollbar-face-color:#f6f6f6;

scrollbar-highlight-color:#fff;

scrollbar-shadow-color:#eeeeee;

scrollbar-3dlight-color:#eeeeee;

scrollbar-arrow-color:#000;

scrollbar-track-color:#fff;

scrollbar-darkshadow-color:#fff;

}

-->

</style>

 

29.    IE6由于默认行高问题无法定义1px左右高度的容器,

 

解决办法:在CSS中对容器设置如:overflow:hidden | zoom:0.08 | line-height:1px

 

30.    Flash设置透明属性可使层显示在Flash之上

 

<param name="wmode" value="transparent" />         <!-- 解决IE上的问题 //>

<embed wmode="transparent" …… >                     <!-- 解决FireFox上的问题 //>

 

31.    FireFox设置Padding属性后会相应的增加WidthHeight属性值,IE不会

 

解决办法:用!important方法多定义一套HeightWidth

 

32.    FireFoxdivdiv之间的空格是忽略的,但IE是处理的;因此尽量在两个相连的div之间不要有空格和回车,否则可能会造成不同浏览器之间格式不正确,比如著名的3px偏差;而且原因很难查明

 

33.    形如如下格式

<div id="parent">

<div id="content"> </div>

</div>

Content内容多时,即使parent设置了高度100%auto,在不同浏览器下还是不能完好的自动伸展;解决办法在层的最下方产生一个高度为1的空格,代码如下

<div id="parent">

<div id="content"> </div>

<div style="font: 0px/0px sans-serif;clear: both;display: block"> </div>

</div>

 

34.    IEFireFox对字体small的尺寸解释不同,FireFox13px,IE中为16px

 

35.    IEFireFox对空格的尺寸解释不同,FireFox4px,IE中为8px

 

文止于此,由于作者才疏学浅,文中纰漏在所难免,欢迎大家批评指正、相互交流。

分享到:
评论

相关推荐

    别具光芒——CSS属性、浏览器兼容与网页布局

    "别具光芒——CSS属性、浏览器兼容与网页布局"这个主题涵盖了三个核心概念:CSS属性、浏览器兼容性和网页布局。 首先,我们来详细探讨CSS属性。CSS提供了无数的属性,如颜色、字体、大小、位置等,这些属性共同决定...

    WebRebuild北京第一届交流会之2:《浏览器兼容性问题简介》——黄昊

    浏览器兼容性问题一直是Web开发中的一个关键挑战,尤其是在构建跨平台、多设备的网页时。黄昊在WebRebuild北京第一届交流会上所分享的《浏览器兼容性问题简介》揭示了这些问题的核心及其解决策略。 首先,浏览器...

    postcsspresetenv将现代CSS转换成浏览器能理解的东西

    总的来说,`postcss-preset-env`是现代前端开发中的一个关键工具,它极大地提高了CSS的可维护性和跨浏览器兼容性,使得开发者能够更加专注于功能实现,而非基础的兼容性问题。通过合理的配置和使用,你可以让项目在...

    解决IE5/IE5.5/IE6/FF的兼容性问题——CSS

    ### 解决IE5/IE5.5/IE6/FF的兼容性问题——CSS 随着Web技术的发展,浏览器之间的差异一直是前端开发人员头疼的问题之一。尤其是对于早期的浏览器(如Internet Explorer 5/5.5/6 和 Firefox),由于它们对CSS的支持...

    css多浏览器兼准则

    这两种策略有助于确保广泛的浏览器兼容性。 3. **使用CSS重置或Normalize.css**:每个浏览器都有自己的默认样式,这可能导致在不同浏览器下页面表现不一致。通过使用CSS重置(如Eric Meyer Reset)或Normalize.css...

    CSS参考手册——CSS基础

    由于历史原因,不同浏览器对CSS的支持程度不同,需关注兼容性问题。使用CSS前缀(如`-webkit-`、`-moz-`等)来支持较老的浏览器,并考虑使用Autoprefixer自动添加前缀。 **九、预处理器与后处理器** 1. **预处理器*...

    区别不同浏览器CSS hack

    通过对上述示例的分析,我们可以清晰地看到如何利用CSS Hack来解决浏览器兼容性问题。通过精心设计这些Hack,开发者可以确保网页在不同浏览器中展现出一致的外观。然而,随着现代浏览器的发展和CSS标准的不断完善,...

    样式表教程——CSS

    10. **浏览器兼容性**:理解CSS各版本之间的差异,以及如何使用工具和技巧解决浏览器兼容性问题,例如使用Autoprefixer自动添加浏览器前缀。 11. **预处理器**:介绍Sass、Less等CSS预处理器,它们提供变量、嵌套...

    兼容性测试方案-浏览器编

    对于基于Web的应用程序而言,浏览器兼容性测试尤为关键,因为用户可能使用多种不同类型的浏览器访问网站或应用。这包括但不限于IE、Firefox、Google Chrome、Safari、Opera以及各种基于这些核心的衍生浏览器如360...

    web开发——CSS语法(二).docx

    然而,浏览器之间的兼容性问题常常导致继承不一致。比如,老版本的Netscape 4不支持继承,而早期的Internet Explorer/Windows(直到IE6)在表格内部存在字体样式忽略的问题。为了解决这些问题,开发者通常需要编写...

    JavaScript万年历——兼容多浏览器

    由于JavaScript在不同的浏览器中可能存在差异,因此实现一个兼容多浏览器的万年历功能需要考虑浏览器的兼容性问题,确保在IE、Chrome、Firefox、Safari等主流浏览器上都能正常运行。 万年历的设计通常包括以下几个...

    精品CSS软件包八款之1——css编辑内置预览 _CFi StylePad 1.3.2 汉化版

    虽然现在CSS已经发展到更高级的版本(如CSS3),但对CSS1和CSS2的支持仍然对处理一些老项目或兼容性问题很有价值。 CFi StylePad的内置预览功能是其核心亮点。在传统的CSS编写过程中,开发者通常需要在代码编辑器和...

    多浏览器兼容分析

    然而,这也带来了新的挑战——不同的浏览器对同一网页的呈现可能产生差异,这就是所谓的“浏览器兼容性问题”。 #### 二、浏览器兼容性问题分类 浏览器兼容性问题大致可归类为三类: 1. **渲染相关**:涉及样式和...

    css浏览器兼容性前端人员的必备

    ### CSS浏览器兼容性——前端开发者的必备技能 #### 一、引言 随着Web技术的发展,前端开发变得越来越重要。为了确保网站能够在不同浏览器中稳定运行,了解并掌握CSS的浏览器兼容性技巧至关重要。本文主要介绍了...

    标记语言——CSS布局

    除此之外,本章还会讨论其他布局方法,如定位布局(Positioning),以及如何处理Internet Explorer 5.0的盒模型问题,这在跨浏览器兼容性方面非常重要。此外,还将揭示一个简单的技巧,如何使用CSS实现等宽栏位布局...

    CSS浏览器兼容问题整理(IE6.0、IE7.0_与_FireFox)

    总之,CSS浏览器兼容性问题需要Web开发者具备深入的理解和精细的调试技巧。通过采用正确的布局策略、使用跨浏览器兼容的CSS属性、以及在必要时引入针对性的解决方案,可以有效减轻这些兼容性问题带来的困扰,确保...

    图片浏览器——JS

    5. 兼容性和性能优化:考虑到不同浏览器的兼容性问题,可能需要使用polyfill或条件语句来确保代码在各种环境下都能正常工作。同时,合理管理内存和减少HTTP请求可以提升图片浏览器的性能。 6. 响应式设计:随着移动...

    CSS+DIV浏览器兼容技巧

    此外,CSS hack 也是处理浏览器兼容性问题的常见手段。例如: - 区分 IE6 和 FF:`background: orange; *background: blue;` - 区分 IE6 和 IE7:`background: green !important; background: blue;` - 区分 IE7 和...

    css教程————快速掌握css

    12. **浏览器兼容性**:了解不同浏览器对CSS特性的支持程度很重要。使用浏览器前缀(如 `-webkit-`)和工具(如Autoprefixer)可以帮助解决兼容性问题。 通过深入学习以上知识点,并在"五日精通Css"的实践中不断...

    浏览器兼容

    浏览器兼容性是Web开发中的一个核心议题,它涉及到不同浏览器对HTML、CSS、JavaScript以及其他Web技术的解析和执行方式的差异。确保网站或应用在所有主流浏览器上都能正常运行是开发者的重要任务。以下是对这个主题...

Global site tag (gtag.js) - Google Analytics