获得本站免费赞助空间请点这里
返回列表 发帖

ie firefox 兼容CSS的问题

CSS对浏览器的兼容性具有很高的要求,通常情况下IE和Firefox(简称FF)存在很大的解析差异,这里介绍一下兼容要点。
. K4 F( B2 o& D% e% v) ]6 B4 w3 m7 T. C3 }- e
  常见的兼容问题:
% a# g+ y& B0 H9 E6 C+ j# B0 `0 g9 y% u8 D; I
  1.DOCTYPE 影响 CSS 处理; }7 t& [/ |9 X; ^0 F
+ t# C9 p' P, Q1 D/ P& Q9 u8 m
  2.FF: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行+ [0 y) a' N- N9 E  ^* ~4 ~
% \$ j8 s) G+ ]" y7 ]
  3.FF: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中: t7 e$ e5 P/ L0 B& X, {

3 D/ g" m3 `+ T. y' Y  4.FF: 设置 padding 后, div 会增加 height 和 width, 但 IE 不会, 故需要用 !important 多设一个 height 和 width
( [) m: U1 }+ y/ f% J" _( i% V* u+ `& F* f
  5.FF: 支持 !important, IE 则忽略, 可用 !important 为 FF 特别设置样式, j, R" _+ q/ v; r& W. z) D

) g& \- [* l  f! R1 d9 R& z& `  6.div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
& k8 L% n; d5 Q1 x5 h6 K; y5 [) n
  7.cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
  \7 W$ K% t$ [) S! U2 v3 a6 n
& l5 A" y# _9 [7 k4 ~2 d7 u  8.FF: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格。* A% X  R# b+ j0 j

! D# d8 Z9 k/ M- W; x1 {6 S  9.在mozilla firefox和IE中的BOX模型解释不一致导致相差2px解决方法: div{margin:30px!important;margin:28px;}2 B, _: }1 O$ b+ G& j
  注意这两个margin的顺序一定不能写反,据阿捷的说法!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样: div{maring:30px;margin:28px}: X5 H+ L) s& H, `) Y( M3 k0 b
  重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;
0 Q4 q3 Q: d: [) W
/ z8 V' |" v8 O6 x- c( P, C4 `  10.IE5 和IE6的BOX解释不一致
7 b( g: o7 k" O' J. z  IE5下 div{width:300px;margin:0 10px 0 10px;}
( N* o' t3 m) }4 ]- Y  div的宽度会被解释为300px-10px(右填充)-10px(左填充)最终div的宽度为280px,而在IE6和其他浏览器上宽度则是以300px+10px(右填充)+10px(左填充)=320px来计算的。这时我们可以做如下修改 div{width:300px!important;width /**/:340px;margin:0 10px 0 10px}
7 _$ I+ Q8 _9 C  关于这个/**/是什么我也不太明白,只知道IE5和firefox都支持但IE6不支持
1 V1 @& B3 [1 B) o3 L) q# G- _* P8 o7 [6 G8 U3 o* |
  11.ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值所以先定义 ul{margin:0;padding:0;} 就能解决大部分问题
- b) H: \7 J0 P6 z5 {$ p+ p, n5 M$ c$ Y, g* h* m
  注意事项:
' d  `) q* P* _# k$ U( a/ S! j: |0 i7 O1 Z+ I& x( S( O1 U
  1、float的div一定要闭合。
( ^; D5 X9 P& N; @6 t) _) x
3 R* ~) B% A. r* T  例如:(其中floatA、floatB的属性已经设置为float:left;) , }/ A) \5 j$ i" _% N# X
<#div id="floatA" ></#div># U4 F" Y* ?) X# {
<#div id="floatB" ></#div>
, [+ i& O+ G, [4 v+ v8 F<#div id="NOTfloatC" ></#div>- m, E) m. l% G; M- P5 h
  这里的NOTfloatC并不希望继续平移,而是希望往下排。+ ]/ e* M' [) h
  这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。
5 U* T+ x7 S) a1 ~  在 <#div class="floatB"></#div>2 T" z& e7 q1 V, ~
<#div class="NOTfloatC"></#div>
! F1 j, K8 D) Z# {. q" |3 g) R  之间加上 <#div class="clear"></#div>
* i) }" V* i9 w: R# |  这个div一定要注意声明位置,一定要放在最恰当的地方,而且必须与两个具有float属性的div同级,之间不能存在嵌套关系,否则会产生异常。, Y" g: H4 c. P- R5 R7 _
  并且将clear这种样式定义为为如下即可: .clear{
& @( K0 R+ h) L9 Vclear:both;}, T) l% c5 V0 e% M& t) m& u4 y
  此外,为了让高度能自动适应,要在wrapper里面加上overflow:hidden;% y$ [5 ^8 f7 F6 T0 u
  当包含float的box的时候,高度自动适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。
1 D0 K0 a. q, u) V/ W5 Q  例如某一个wrapper如下定义: .colwrapper{: M; ?. u7 Z' z3 U, d- z
overflow:hidden;
0 H* B/ \8 s6 W) X' Xzoom:1;% \% }# q( o' O9 {; L; i  V
margin:5px auto;}
* s0 o( f4 z. |. ?% n( d; t. ]' S* G) X! a
  2、margin加倍的问题。! [( y9 O; C) K6 [4 l$ x

& y! c2 G2 t5 w7 z1 Y# V% E9 ~4 g  设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。# R1 d0 N* Y4 d
  解决方案是在这个div里面加上display:inline;3 z/ F0 [6 u# k6 R# ~) c0 ?: a8 O# A
例如:
' y% l# q/ W+ a! J, r2 q<#div id="imfloat"></#div>4 o; K4 d- F4 S  w" A; T

7 J6 l8 d: m. ?& B, \
2 V  ]2 A- k/ i6 s# L  相应的css为
4 q/ k9 h' F+ u5 _# q#IamFloat{; `4 g! e. [, [
float:left;0 v  |7 f" Q9 ]6 [" a9 g
margin:5px;/*IE下理解为10px*/
- T1 ]. s2 S4 y2 _display:inline;/*IE下再理解为5px*/}
6 ~  t* \) V( P
/ o, P* x8 T, `/ K  3、关于容器的包涵关系% A/ }4 ?4 u% M; G2 e6 v5 g; Y

. V* d' a  J; h: V( ^9 p5 ~. U) @  很多时候,尤其是容器内有平行布局,例如两、三个float的div时,宽度很容易出现问题。在IE中,外层的宽度会被内层更宽的div挤破。一定要用Photoshop或者Firework量取像素级的精度。" b- o; P0 \8 l  H( u6 w7 b, B* F+ r/ Y) R

% d0 F* l) ?! a- P  4、关于高度的问题$ L* j* C2 k3 _$ H' r" p
  \/ t3 e# A5 C# f
  如果是动态地添加内容,高度最好不要定义。浏览器可以自动伸缩,然而如果是静态的内容,高度最好定好。(似乎有时候不会自动往下撑开,不知道具体怎么回事)
  b+ ]8 u: I; l; K! D. Y, Y2 C4 v3 C
* w; a- ~0 y, D( V+ j  5、最狠的手段 - !important;' \- ~; @8 a7 H$ o" Q  M3 s

9 D0 [, {' V" B- v2 Y! H* j  如果实在没有办法解决一些细节问题,可以用这个方法.FF对于"!important"会自动优先解析,然而IE则会忽略.如下 .tabd1{+ _0 v3 Z& X+ i1 @+ }+ L+ u3 h
background:url(/res/images/up/tab1.gif) no-repeat 0px 0px !important; /*Style for FF*/: R; e. F1 O- Q( Z: ?  ]5 O/ U' ^
background:url(/res/images/up/tab1.gif) no-repeat 1px 0px; /* Style for IE */}
, B6 \% S2 T! z4 F; x9 |: _  值得注意的是,一定要将xxxx !important 这句放置在另一句之上,上面已经提过

返回列表
【捌玖网络】已经运行: