CSS对浏览器器的兼容性具有很高的价值,通常情况下IE和Firefox存在很大的解析差异,这里介绍一下兼容要点。
常见兼容问题:
1.DOCTYPE 影响 CSS 处理
2.FF: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行
3.FF: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中
4.FF: 设置 padding 后, div 会增加 height 和 width, 但 IE 不会, 故需要用 !important 多设一个 height 和 width
5.FF: 支持 !important, IE 则忽略, 可用 !important 为 FF 特别设置样式
6.div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
7.cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
8.FF: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格。
9.在mozilla firefox和IE中的BOX模型解释不一致导致相差2px解决方法:
div{margin:30px!important;margin:28px;}
注意这两个margin的顺序一定不能写反,据阿捷的说法!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样:
div{maring:30px;margin:28px}
重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;
10.IE5 和IE6的BOX解释不一致
IE5下
div{width:300px;margin:0 10px 0 10px;}
div的宽度会被解释为300px-10px(右填充)-10px(左填充)最终div的宽度为280px,而在IE6和其他浏览器上宽度则是以300px+10px(右填充)+10px(左填充)=320px来计算的。这时我们可以做如下修改
div{width:300px!important;width /**/:340px;margin:0 10px 0 10px}
关于这个/**/是什么我也不太明白,只知道IE5和firefox都支持但IE6不支持,如果有人理解的话,请告诉我一声,谢了!:)
11.ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值所以先定义
ul{margin:0;padding:0;}
就能解决大部分问题
注意事项:
1、float的div一定要闭合。
例如:(其中floatA、floatB的属性已经设置为float:left;)
<#div id="floatA" ></#div>
<#div id="floatB" ></#div>
<#div id="NOTfloatC" ></#div>
这里的NOTfloatC并不希望继续平移,而是希望往下排。
这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。
在
<#div class="floatB"></#div>
<#div class="NOTfloatC"></#div>
之间加上
<#div class="clear"></#div>
这个div一定要注意声明位置,一定要放在最恰当的地方,而且必须与两个具有float属性的div同级,之间不能存在嵌套关系,否则会产生异常。
并且将clear这种样式定义为为如下即可:
.clear{
clear:both;}
此外,为了让高度能自动适应,要在wrapper里面加上overflow:hidden;
当包含float的box的时候,高度自动适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。
例如某一个wrapper如下定义:
.colwrapper{
overflow:hidden;
zoom:1;
margin:5px auto;}
2、margin加倍的问题。
设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。
解决方案是在这个div里面加上display:inline;
例如:
<#div id="imfloat"></#div>
相应的css为
#IamFloat{
float:left;
margin:5px;/*IE下理解为10px*/
display:inline;/*IE下再理解为5px*/}
3、关于容器的包涵关系
很多时候,尤其是容器内有平行布局,例如两、三个float的div时,宽度很容易出现问题。在IE中,外层的宽度会被内层更宽的div挤破。一定要用Photoshop或者Firework量取像素级的精度。
4、关于高度的问题
如果是动态地添加内容,高度最好不要定义。浏览器可以自动伸缩,然而如果是静态的内容,高度最好定好。(似乎有时候不会自动往下撑开,不知道具体怎么回事)
5、最狠的手段 - !important;
如果实在没有办法解决一些细节问题,可以用这个方法.FF对于"!important"会自动优先解析,然而IE则会忽略.如下
.tabd1{
background:url(/res/images/up/tab1.gif) no-repeat 0px 0px !important; /*Style for FF*/
background:url(/res/images/up/tab1.gif) no-repeat 1px 0px; /* Style for IE */}
分享到:
相关推荐
### CSS兼容问题详解 在网页开发过程中,不同的浏览器由于对CSS的支持程度不同,常常会导致页面在各个浏览器中的表现不一致,这就是所谓的“CSS兼容性问题”。本文将详细探讨几个常见的CSS兼容性问题及其解决方法。...
### 浏览器的CSS兼容问题详解 在Web开发领域,浏览器兼容性一直是开发者们头疼的问题,尤其是在处理CSS样式时。不同的浏览器内核对CSS的支持程度、解析方式以及渲染效果存在差异,这使得同一段代码在不同浏览器下...
### CSS兼容问题的解决方案 #### 一、概述 在网页设计与开发过程中,开发者经常会遇到不同浏览器对于CSS的支持程度不一的问题,导致页面在不同浏览器中的显示效果出现差异。为了确保网页能够在各种浏览器中正常...
### IE与Firefox的CSS兼容问题:web2.0经验总结 在Web开发中,确保不同浏览器之间的CSS兼容性是一项挑战性的任务,尤其是在处理Internet Explorer(IE)与Firefox这两种具有显著差异的浏览器时。本文将深入探讨IE与...
十二、IE与Firefox的CSS兼容问题 1. 字体渲染:IE可能对某些字体有不同解析,可以使用`font-family`指定多种字体作为备选。 2. 盒模型差异:IE6和7使用不同的盒模型,可以通过`box-sizing`属性或`*{box-sizing:...
html编写中存在div+css兼容问题,该文档阐述了网页编写的兼容性问题
### 各种浏览器的CSS兼容问题 在网页开发过程中,我们经常会遇到不同浏览器对CSS的支持程度不一的问题,这使得同样的CSS代码在不同的浏览器中可能会呈现出不同的效果。本文将详细介绍几种主流浏览器(IE、Firefox、...
解决CSS兼容性问题的两种常见方法是: 1. 使用`!important`标记:在CSS中,`!important`可以强制应用某个样式,但这可能导致优先级混乱。例如: ```css #wrapper { width: 100px !important; /* IE7+FF */ ...
在网页设计领域,CSS(Cascading ...总的来说,处理CSS兼容性问题需要对各种浏览器的特性有深入理解,并掌握一定的技巧和工具。通过学习和实践,我们可以更好地应对这些挑战,创建出在多种浏览器下都能完美展现的网页。
CSS 在不同浏览器中的兼容问题 CSS 在不同浏览器中的兼容问题是 web 开发中的一大挑战。不同的浏览器对 CSS 的解析和渲染方式存在差异,从而导致相同的 CSS 代码在不同浏览器中显示效果不同。本文将总结常见的 CSS ...
浏览器兼容常见问题css兼容 css兼容 浏览器兼容 IE6789兼容
在前端开发中,兼容性问题是一个经常遇到且难以回避的问题,特别是CSS兼容问题。由于浏览器市场中存在多种不同的浏览器,每种浏览器又有其特定的内核(渲染引擎),这就导致了不同的浏览器对网页内容的解析规则有所...
本文将对主流浏览器,特别是Chrome、Firefox、Internet Explorer(简称IE)8、9、11以及360浏览器中的CSS兼容问题进行梳理,并提供一些解决办法。 首先,关于IE浏览器的CSS兼容问题。IE7以下版本已逐渐淡出市场,...
这个资源“最全的CSS浏览器兼容问题”显然是一个非常实用的文档,它详细列举了在开发过程中可能遇到的各种CSS兼容问题及其解决方案,旨在帮助开发者更好地处理跨浏览器的样式问题。 首先,我们需要理解浏览器兼容性...
首先,理解“盒模型”是解决兼容问题的基础。IE6、7采用的怪异盒模型与W3C标准盒模型不同,导致边距和内填充计算方式有别。为确保一致性,可以使用`box-sizing:border-box`或`*{box-sizing:border-box}`来统一所有...
CSS兼容问题一直是前端开发者在网页设计和开发中遇到的常见难题之一。随着互联网技术的发展,浏览器种类和版本不断更新,各个浏览器对CSS的解析也存在差异,这就造成了不同浏览器间显示效果的不一致。为了解决这些...
- 题目中的部分内容提到了一些具体的CSS兼容性问题,例如: - 在IE6和IE7中,当设置`div`的`margin-left`和`margin-right`为`auto`时,可能出现居中显示的问题。 - Firefox对`body`的`text-align`属性支持不同于...
以下是一些解决这些浏览器间CSS兼容问题的方法: 1. **DOCTYPE声明**:DOCTYPE声明会影响浏览器的呈现模式。在HTML文档开头使用正确的DOCTYPE声明,如`<!DOCTYPE html>`,可以确保浏览器以标准模式解析CSS,减少...
其中,CSS兼容性问题尤为突出。本文将重点介绍针对IE8正式版的CSS hack技巧,并探讨如何有效地解决CSS在不同浏览器间的兼容性问题。 #### 二、CSS Hack概述 **CSS Hack**是一种通过特定语法让某些浏览器解析不同的...
CSS兼容问题是指不同的浏览器在解析和呈现CSS样式时存在差异,导致相同代码在不同浏览器上显示效果不一致。这个问题的出现主要是因为各个浏览器厂商对CSS规范的实现不尽相同,有的浏览器可能完全遵循W3C标准,有的则...