|
  
- UID
- 1
- 帖子
- 738
- 精华
- 28
- 积分
- 14321
- 金币
- 2446
- 威望
- 1647
- 贡献
- 1394
|
CSS对浏览器的兼容性具有很高的要求,通常情况下IE和Firefox(简称FF)存在很大的解析差异,这里介绍一下兼容要点。1 Z* i, j+ |* V- i; w
! l* p* x6 [; n, U- D
常见的兼容问题:7 m+ O" p3 k, Q/ d# b# Q
}, d2 y1 c( N0 r# m9 u$ B 1.DOCTYPE 影响 CSS 处理" N" @, r! y- j8 o5 b' F, b
3 r! O0 C$ i/ p: u" V% p
2.FF: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行
# x/ m- M* G' \/ U3 ^% m+ F- F2 |( u" c, K5 ~ S$ W
3.FF: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中$ W" H/ v2 h/ ^1 l7 c3 j# G
5 w* P/ b6 O4 b
4.FF: 设置 padding 后, div 会增加 height 和 width, 但 IE 不会, 故需要用 !important 多设一个 height 和 width
+ ~7 F& G4 Y/ q+ r! K
* ]5 M) L* w* N0 e2 D+ O 5.FF: 支持 !important, IE 则忽略, 可用 !important 为 FF 特别设置样式
7 `# d5 k3 s7 F' l4 d- [: g2 b
0 e& Q$ Q6 Y6 D 6.div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行
" U- W0 u, u- o) X; x0 l6 z! Q" R h# K+ k! v
7.cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以. h( k: S" e2 I Z- D5 x
# M! C* g" F% N 8.FF: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格。- Y4 P3 k9 T, v
3 W! m% |' t& F+ Y( K
9.在mozilla firefox和IE中的BOX模型解释不一致导致相差2px解决方法: div{margin:30px!important;margin:28px;}" @' p3 n% X( D2 m
注意这两个margin的顺序一定不能写反,据阿捷的说法!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样: div{maring:30px;margin:28px}. }5 A8 ~! e" s4 d9 E- e
重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;( ~' b/ U. O% P$ _# ]4 U8 }
$ j& Z- G/ x' |2 L5 P. J 10.IE5 和IE6的BOX解释不一致" X4 x3 L8 k; p! T6 y
IE5下 div{width:300px;margin:0 10px 0 10px;}
! d# {9 T+ f6 f5 R4 ?7 N( j' L( L div的宽度会被解释为300px-10px(右填充)-10px(左填充)最终div的宽度为280px,而在IE6和其他浏览器上宽度则是以300px+10px(右填充)+10px(左填充)=320px来计算的。这时我们可以做如下修改 div{width:300px!important;width /**/:340px;margin:0 10px 0 10px}
, f$ z3 {9 l7 T 关于这个/**/是什么我也不太明白,只知道IE5和firefox都支持但IE6不支持+ `. _9 ~! N7 G+ c6 y5 F4 l+ J8 G
/ E2 l+ H% p- f* l x( J7 _$ |# w" n
11.ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值所以先定义 ul{margin:0;padding:0;} 就能解决大部分问题# d( G4 c6 ^8 r" `% w+ p+ m" ^
2 a9 e6 H8 H3 j% s! T$ C. I
注意事项:
! v6 ^9 b" R5 j( D6 ~$ M9 M
/ P" E% ?, W: C1 w/ l0 r$ I3 u& T 1、float的div一定要闭合。
3 K& H8 `0 c8 F5 c! k; F; F1 k T. U% Y
例如:(其中floatA、floatB的属性已经设置为float:left;)
% b, p2 V+ |; D4 ^6 m& h9 Z5 o<#div id="floatA" ></#div>: N/ i: ^2 W; B4 n) {- L
<#div id="floatB" ></#div>3 V9 h& T7 R* d0 u& Y) q
<#div id="NOTfloatC" ></#div>
' b% B+ ^; c: P y 这里的NOTfloatC并不希望继续平移,而是希望往下排。" K# z" r( g: Q T
这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。, O7 l' _8 E" ?* Z1 f
在 <#div class="floatB"></#div>9 y8 {- y# E1 [7 a3 @' x
<#div class="NOTfloatC"></#div>: h, ?; x! H! Y' {3 Z. S2 t
之间加上 <#div class="clear"></#div>
% w$ |/ e% T: \9 M: W* V% N 这个div一定要注意声明位置,一定要放在最恰当的地方,而且必须与两个具有float属性的div同级,之间不能存在嵌套关系,否则会产生异常。
0 q& s% c, @8 _$ e) @ 并且将clear这种样式定义为为如下即可: .clear{! c# m4 |5 H- B
clear:both;}
3 X6 f( s& v2 j7 i3 [! R 此外,为了让高度能自动适应,要在wrapper里面加上overflow:hidden;; \) L3 K7 N- ?* _, k& r" I
当包含float的box的时候,高度自动适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。
# |/ @. Y% E- S" Q9 H! j5 q 例如某一个wrapper如下定义: .colwrapper{
9 M2 K# `0 x+ d& Poverflow:hidden;
. C2 y' D8 M- X# y! Zzoom:1;
5 @6 |3 O/ a3 H9 \margin:5px auto;}9 W) j4 ?# K3 K, U2 y; [: X
6 _( w% y9 ? d* m0 l% W
2、margin加倍的问题。; U/ m$ I. O( Q# i
+ e( f6 U' P( U3 J/ R2 a0 L
设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。
7 T8 L4 a- {. d3 O+ o/ h9 j 解决方案是在这个div里面加上display:inline;) |0 Y( z5 a: [) Y8 b6 c0 k2 G3 d
例如:) d3 ^, O I N8 s# }
<#div id="imfloat"></#div>0 `; m% }; h' j+ h4 _ U
5 x8 E( @- @# ?0 v) q" K
+ e2 X0 ~1 `; p+ ?& [
相应的css为
2 k/ C; S+ }3 V& H2 _#IamFloat{
( K# e4 o3 X) K. ?9 ^1 D- `float:left;6 N6 Y( E5 E( ^) d+ ^6 C
margin:5px;/*IE下理解为10px*/
( i+ O4 V+ J' r/ K- ldisplay:inline;/*IE下再理解为5px*/}4 N) U" c2 g0 K. i& t7 w2 \
+ A! k: @, x/ D6 P0 g, H
3、关于容器的包涵关系# \9 o2 }' S [( t+ p) _. K
! `4 G: W2 V! D1 G) } 很多时候,尤其是容器内有平行布局,例如两、三个float的div时,宽度很容易出现问题。在IE中,外层的宽度会被内层更宽的div挤破。一定要用Photoshop或者Firework量取像素级的精度。
( Z2 J5 v! F0 i- |8 J5 [; `6 g2 j9 v; T
% C& y% C8 E6 N" j3 u( Z 4、关于高度的问题8 h# R* ~2 K7 I: V- F
5 E2 b; b, t6 t2 B7 \ 如果是动态地添加内容,高度最好不要定义。浏览器可以自动伸缩,然而如果是静态的内容,高度最好定好。(似乎有时候不会自动往下撑开,不知道具体怎么回事)
1 R3 ]/ D9 t F: X
0 _! U8 n1 P7 j3 _$ v5 R9 U 5、最狠的手段 - !important;
; d0 `/ e4 K" u# h$ c/ G
* w' S4 }' P' Y' J5 H1 _5 L 如果实在没有办法解决一些细节问题,可以用这个方法.FF对于"!important"会自动优先解析,然而IE则会忽略.如下 .tabd1{% K: c% f( J. X4 t8 `" e
background:url(/res/images/up/tab1.gif) no-repeat 0px 0px !important; /*Style for FF*/
+ ?. B8 v' [) `; J) Wbackground:url(/res/images/up/tab1.gif) no-repeat 1px 0px; /* Style for IE */}* h! ]0 Y% r& D) _7 b, X. x3 D
值得注意的是,一定要将xxxx !important 这句放置在另一句之上,上面已经提过 |
|