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

ie firefox 兼容CSS的问题

CSS对浏览器的兼容性具有很高的要求,通常情况下IE和Firefox(简称FF)存在很大的解析差异,这里介绍一下兼容要点。7 m- v. I; [& {( `7 e3 t* w

5 z( \! P& x; s, T2 r  常见的兼容问题:
  \* Q2 C8 K3 i
! L* e, }5 [9 K7 D  1.DOCTYPE 影响 CSS 处理
- S6 Y+ _# o* C6 m: v+ t: ?, [: M
  l2 ?! T+ n% @1 A  2.FF: div 设置 margin-left, margin-right 为 auto 时已经居中, IE 不行$ g6 y9 @3 W0 y& b% B

* f& `$ l; [& [  3.FF: body 设置 text-align 时, div 需要设置 margin: auto(主要是 margin-left,margin-right) 方可居中
; a% Z# l6 |# M9 D* z  g; a; ^0 w1 r& m5 I1 T  B
  4.FF: 设置 padding 后, div 会增加 height 和 width, 但 IE 不会, 故需要用 !important 多设一个 height 和 width* B& i2 D. r: b9 j, b

! m; {4 t/ K& [8 i  5.FF: 支持 !important, IE 则忽略, 可用 !important 为 FF 特别设置样式1 P* m6 z4 ^4 I" c; P

: ~' D2 s- n+ J9 @$ a3 g/ [  6.div 的垂直居中问题: vertical-align:middle; 将行距增加到和整个DIV一样高 line-height:200px; 然后插入文字,就垂直居中了。缺点是要控制内容不要换行2 V& z* F8 k/ Q# C& b" d$ G1 v
0 |' P# L: X; _! F# T; Y, U* C
  7.cursor: pointer 可以同时在 IE FF 中显示游标手指状, hand 仅 IE 可以
! W6 B' \8 B$ I! x6 d% z+ |( }: ^+ R$ W: _# @
  8.FF: 链接加边框和背景色,需设置 display: block, 同时设置 float: left 保证不换行。参照 menubar, 给 a 和 menubar 设置高度是为了避免底边显示错位, 若不设 height, 可以在 menubar 中插入一个空格。# p% H- R3 d" ?3 K$ o- t# b/ F
8 ~9 {' n( w* n+ I5 o6 o
  9.在mozilla firefox和IE中的BOX模型解释不一致导致相差2px解决方法: div{margin:30px!important;margin:28px;}% S& Q5 n; g. H' h9 ]- I
  注意这两个margin的顺序一定不能写反,据阿捷的说法!important这个属性IE不能识别,但别的浏览器可以识别。所以在IE下其实解释成这样: div{maring:30px;margin:28px}2 b( V* G: {7 D9 B; i7 @
  重复定义的话按照最后一个来执行,所以不可以只写margin:XXpx!important;3 E# B3 L( f- w* I4 B( ^* C

! l) T7 o" W+ t! A$ m  10.IE5 和IE6的BOX解释不一致
2 o/ g7 w5 M. K( s, U  IE5下 div{width:300px;margin:0 10px 0 10px;}: J8 G" I( ^0 }+ Y( J
  div的宽度会被解释为300px-10px(右填充)-10px(左填充)最终div的宽度为280px,而在IE6和其他浏览器上宽度则是以300px+10px(右填充)+10px(左填充)=320px来计算的。这时我们可以做如下修改 div{width:300px!important;width /**/:340px;margin:0 10px 0 10px}
7 z; T2 h0 A/ {: q2 w  关于这个/**/是什么我也不太明白,只知道IE5和firefox都支持但IE6不支持% v9 c' _: Z: Q& [
, k# R* I( J! o3 l1 n% B+ t
  11.ul标签在Mozilla中默认是有padding值的,而在IE中只有margin有值所以先定义 ul{margin:0;padding:0;} 就能解决大部分问题$ v% {. t- Q( Q$ v9 M, B

. x3 ?: s3 A) y, E( w1 {  注意事项:
4 m, q( t) w/ \) N. h+ X6 Q8 q3 w" E7 w) ^# _) @! w+ t& k  J5 Y2 f
  1、float的div一定要闭合。7 d/ D& e3 n- X) G; T7 `7 R' A7 A, @
! k3 }) I6 J9 A
  例如:(其中floatA、floatB的属性已经设置为float:left;)
6 ?* A. B# i# J4 s1 B7 C" y<#div id="floatA" ></#div>/ p) }+ q6 |; X- G1 I$ J: j3 I
<#div id="floatB" ></#div>% n" c" J4 b( D. n! a7 }" Q) l5 T
<#div id="NOTfloatC" ></#div>
0 D  T$ ]2 f$ W' o% t: ^  这里的NOTfloatC并不希望继续平移,而是希望往下排。
, l; [" _6 N  J# R1 l  这段代码在IE中毫无问题,问题出在FF。原因是NOTfloatC并非float标签,必须将float标签闭合。
1 X) `& v& l% F1 d  在 <#div class="floatB"></#div>0 @; ]0 {% L, |9 f
<#div class="NOTfloatC"></#div>; i; A  x, E& W
  之间加上 <#div class="clear"></#div>! p* l+ \: b+ Q0 A! U
  这个div一定要注意声明位置,一定要放在最恰当的地方,而且必须与两个具有float属性的div同级,之间不能存在嵌套关系,否则会产生异常。
& N8 E/ I! E9 F  a  并且将clear这种样式定义为为如下即可: .clear{7 P$ T8 O3 F4 i, |0 _0 C
clear:both;}
- A5 A4 j3 P) m# Z  R3 t( k9 Z4 R  此外,为了让高度能自动适应,要在wrapper里面加上overflow:hidden;
/ p$ J8 ?$ @9 v. D3 K2 j" n  d  当包含float的box的时候,高度自动适应在IE下无效,这时候应该触发IE的layout私有属性(万恶的IE啊!)用zoom:1;可以做到,这样就达到了兼容。- q- k/ B- d! S
  例如某一个wrapper如下定义: .colwrapper{
( @3 u% n; x) r/ A- f2 z2 noverflow:hidden;$ H! Q4 Q; m5 \3 E+ y! X0 R
zoom:1;
) [" {- Q3 J+ E; K7 ]margin:5px auto;}2 L" N  N- o" w( [3 W& _; O$ [

1 j3 _/ T/ ?" m( V( w  2、margin加倍的问题。+ T  {1 v0 D* a: ]1 v+ z

7 x# ^  C4 v% F8 v$ }  设置为float的div在ie下设置的margin会加倍。这是一个ie6都存在的bug。
3 Z$ ]. k3 c( \& }( f  解决方案是在这个div里面加上display:inline;
+ {) E$ _% v' h- S2 [9 B* B例如:* B" z* G7 R- X+ t4 i6 k+ F# [
<#div id="imfloat"></#div>
- Y/ C/ R7 h$ O# x* E3 A: n" E) i7 |: [" n, M! @

+ F3 u8 u7 r* j: c/ I$ h  相应的css为+ ^+ N* b0 d% A# |( k
#IamFloat{2 E3 h# c0 c4 T  d8 ~6 f0 z3 R  }
float:left;# n+ x4 x5 F2 Q# r; F; i# Y2 J
margin:5px;/*IE下理解为10px*/! L# w5 Y& G* C& t7 h
display:inline;/*IE下再理解为5px*/}
, x; O/ e' r6 L" ^
: o5 ]" G) Y4 P  3、关于容器的包涵关系
& I: d* p$ _: M! d
4 q9 }3 W7 R, I( C8 W  很多时候,尤其是容器内有平行布局,例如两、三个float的div时,宽度很容易出现问题。在IE中,外层的宽度会被内层更宽的div挤破。一定要用Photoshop或者Firework量取像素级的精度。+ n$ M$ _4 n4 q

: e' A* i1 W7 H  4、关于高度的问题
! d4 F- D- H+ u) K: U1 X3 S6 X3 g, W/ p$ R
  如果是动态地添加内容,高度最好不要定义。浏览器可以自动伸缩,然而如果是静态的内容,高度最好定好。(似乎有时候不会自动往下撑开,不知道具体怎么回事)+ |+ v( Y; j( d
* ?3 o2 M8 o0 }" f& m
  5、最狠的手段 - !important;
; v4 A* e. s; @

8 d$ b2 e! D4 K. a6 e" o  如果实在没有办法解决一些细节问题,可以用这个方法.FF对于"!important"会自动优先解析,然而IE则会忽略.如下 .tabd1{% G7 b9 B' L2 c* N
background:url(/res/images/up/tab1.gif) no-repeat 0px 0px !important; /*Style for FF*/
: r+ X* y8 t! C: Ibackground:url(/res/images/up/tab1.gif) no-repeat 1px 0px; /* Style for IE */}8 Y2 q. e5 G7 }% u* S, b* T8 `0 E
  值得注意的是,一定要将xxxx !important 这句放置在另一句之上,上面已经提过

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