簡單說一下div+css佈局
% s% \5 x1 ?) ^0 r: p5 V9 `2 Q1 Z/ s! F
1.CSS佈局常用的方法:# D/ h3 Q3 a# V* R
float : none | left | right
. ^& n( o' u$ ]8 V+ u4 I6 F9 V" X/ Z2 ^% b8 X! R
取值:8 ], ?/ k+ H) p5 C, ^* I
none :? 默認值。對像不飄浮
% U! g, ^* D6 w; Qleft :? 文本流向對象的右邊
' m, H( {7 T- e; Aright :? 文本流向對象的左邊
% J6 y" r/ o; @9 ^( |
- @- v! L1 V& v9 |7 V6 j; O- m! `它是怎樣工作的,看個一行兩列的例子
( }) f ?3 i2 R; @4 r4 S9 g% k" J& i9 j9 ?2 y
xhtml:
1 J/ D2 X' \8 u! n( \' x* q
% Z# l q' k/ C1 G/ I9 R<div id="warp">, i# ?( w+ x% F9 b
<div id="column1">這裡是第一列</div>
! W9 V8 ~% x+ K9 K( u# w3 ^+ J: G5 B<div id="column2">這裡是第二列</div>
( Y8 J2 Q# v* Z( m3 ^8 ?( _<div class="clear"></div>
: A- ~ E V' n" F' B2 _1 @</div>
7 t2 e; {$ n# R: F6 g' V" ACSS:
" |" L; a: c% I+ G# f
& ~# x8 m* _: t: P+ C#wrap{ width:100%; height:auto;}
( S4 a& [' p- J. j#column1{ float:left; width:40%;}5 _+ z) v5 U* S2 g: t
#column2{ float:right; width:60%;}
$ x$ `8 i$ b9 A k% U.clear{ clear:both;}
# h* u) }$ h. N0 Qposition : static | absolute | fixed | relative
1 J5 m, E. T; A6 f9 _: H6 l2 W9 {' |4 q
取值:
. _3 V E4 V) Y! h! w8 S. ~% _$ T! \
static :? 默認值。無特殊定位,對像遵循HTML定位規則
4 B( R1 r7 D6 w6 d( Q o; \absolute :? 將對像從文檔流中拖出,使用 left , right , top , bottom 等屬性相對於其最接近的一個最有定位設置的父對像進行絕對定位。如果不存在這樣的父對象,則依據 body 對象。而其層疊通過 z-index 屬性定義 $ K8 p0 k `* @- m i" ?
fixed :? 未支持。對像定位遵從絕對(absolute)方式。但是要遵守一些規範
8 g4 F+ V+ d& x# ` ]3 drelative :? 對像不可層疊,但將依據 left , right , top , bottom 等屬性在正常文檔流中偏移位置
1 p& w& M3 y* R3 S0 `) }4 }( W- T) E3 T8 R3 K
它來實現一行兩列的例子
% F/ U& H: ]* n/ u- `# C! t* C5 n: s9 X$ S
xhtml:
1 f' N, S0 W g. C3 I
( m! e7 w% |1 H6 L( F8 y<div id="warp"># e; p4 a B+ X# u4 n
<div id="column1">這裡是第一列</div>
9 \4 S/ I8 C# `+ }1 b V8 D5 v<div id="column2">這裡是第二列</div>
/ F; h; \: J0 k* o: G1 M</div>
# q& y2 D3 `2 T) g& SCSS:
) Z7 j7 X2 T1 {" X& p* D) i) @, U5 ^) I' V9 {
#wrap{ position:relative;/*相對定位*/width:770px;}
8 w+ L- K* R9 C/ p#column1{ position:absolute; top:0; left:0; width:300px;}
% O( C1 d) n1 a0 T#column2{position:absolute; top:0; right:0; width:470px;}) f+ k# j0 L7 `, D
他們的區別在哪?
% w# V1 Y, H6 m% _7 _* I
. t1 h1 c6 ]! \5 r+ W: m顯然,float是相對定位的,會隨著瀏覽器的大小和分辨率的變化而改變,而position就不行了,所以一般情況下還是float佈局!8 F% z- G8 |: W _+ ?) `# x9 U
( u: } w a( C. {2 M$ o& c8 L4 H
2.CSS常用佈局實例
+ I$ [) e; e1 V% W! I
7 g2 u* ?' Z' @, o8 a一列
$ `, P- z6 L- P) n) G單行一列
8 c2 m+ n2 |& i; k1 U: G% j2 _
: q: w/ o# a3 T+ t( d% Kbody { margin: 0px; padding: 0px; text-align: center; }$ } p( s8 k$ w: q
#content { margin-left:auto; margin-right:auto; width: 400px; width: 370px; }
' R& m2 V& M* w6 f4 e兩行一列! s7 t! w- d# x5 M& K$ i3 L
, _) i7 f2 z& N/ z- K
body { margin: 0px; padding: 0px; text-align: center;}/ Y9 d4 Y% p% P3 _' a4 [; t
#content-top { margin-left:auto; margin-right:auto; width: 400px; width: 370px;}- Q4 r* z# F& N
#content-end {margin-left:auto; margin-right:auto; width: 400px; width: 370px;}
6 g0 N& {, C% p6 H4 W( I Y三行一列# g2 P- _5 U+ h; U( y
8 u# A4 V# r- T# C: r# f6 w5 }5 W
body { margin: 0px; padding: 0px; text-align: center; }
0 o4 D$ t# E$ Q# ^$ w! L#content-top { margin-left:auto; margin-right:auto; width: 400px; width: 370px; }9 M9 D$ D( d5 |1 m3 P: T( {
#content-mid { margin-left:auto; margin-right:auto; width: 400px; width: 370px; }
: Y; t1 w# \5 p1 x+ }% E#content-end { margin-left:auto; margin-right:auto; width: 400px; width: 370px; } p: p9 c+ _7 e; x! ?) \7 k8 c
兩列
: R# @/ W% o- h3 t% O, H' Y單行兩列+ D ]! P) t- [! t8 z# I
$ @6 F- E3 i4 O$ i/ @#bodycenter { width: 700px;margin-right: auto; margin-left: auto;overflow: auto; }1 D4 u# {8 | d& j
#bodycenter #dv1 {float: left;width: 280px;}; P, C+ g0 E4 K' ]9 R
#bodycenter #dv2 {float: right;width: 410px;}+ s+ a2 d, r: p$ s; Z
兩行兩列# F! ]6 }1 m! q* R) p8 t
5 X- m4 N& i. C i- R4 z/ _
#header{ width: 700px; margin-right: auto;margin-left: auto; overflow: auto;}2 G& h0 W- h5 O# _( Y! M
#bodycenter { width: 700px; margin-right: auto; margin-left: auto; overflow: auto; }" q+ Q! ?4 s( w3 C" g( f
#bodycenter #dv1 { float: left; width: 280px;}
5 l. B" X/ d8 i8 J/ W#bodycenter #dv2 { float: right;width: 410px;}
: U) F( D* }3 g \三行兩列2 Y# M* p- `) C/ m6 ?! _) H; X
9 X0 q) C7 D( S' K
#header{ width: 700px;margin-right: auto; margin-left: auto; }
M5 u1 N5 z( Z#bodycenter {width: 700px; margin-right: auto; margin-left: auto; }
- n% j; g/ s- g6 j3 R1 M#bodycenter #dv1 { float: left;width: 280px;}
# N# G% Z4 m8 I1 D6 L6 J$ }+ I#bodycenter #dv2 { float: right; width: 410px;}
Q- ]( W: h8 u* F* n- h( u#footer{ width: 700px; margin-right: auto; margin-left: auto; overflow: auto; }
& G5 S) y& n" M' W6 F三列+ ^5 U% V/ u a3 p) ^
單行三列/ s+ _7 S9 u* Q9 l6 t
絕對定位
! D2 ]# I6 a, O" Q" g0 C% p7 X( ~
#left { position: absolute; top: 0px; left: 0px; width: 120px; }
+ d" O1 v# v& V2 ~5 t9 I#middle {margin: 20px 190px 20px 190px; } L$ \; C$ h' y+ j
#right {position: absolute;top: 0px; right: 0px; width: 120px;}
- W( h1 @: L/ p2 ~0 Zfloat定位7 u& z7 X3 r7 |% f4 ?
6 l+ o" m9 t' Dxhtml:
% u7 }) i) e5 ^5 Z5 d9 U' P
( y- ?( p* I$ a" M: p5 C2 ]& M<div id="warp">
3 j7 d9 h# {2 d$ W<div id="column">
5 q j$ M+ ^, S" l8 ~1 R" B" y% m<div id="column1">這裡是第一列</div>
- a. i7 i, i# j m/ b<div id="column2">這裡是第二列</div>
/ S1 }1 a# M' N! ~<div class="clear"></div>
$ \7 c' C2 Z4 I; p) `8 `</div>
4 `: D" o# x& A( U' {$ W<div id="column3">這裡是第三列</div>
( `' Y6 e6 I0 B9 A<div class="clear"></div>
7 I- s/ R; {' F3 }' O# d</div>
0 l! o4 w& v6 ECSS:" b( d* O3 t3 G7 g- D+ k2 z% A
* A8 u U: E5 X" j+ t: ]#wrap{ width:100%; height:auto;}
: U# c& m) O8 C. I! p#column{ float:left; width:60%;}6 ]- y5 f/ W' |; ~
#column1{ float:left; width:30%;}
/ s% i- f. g/ |+ n#column2{ float:right; width:30%;}
% ]; u4 F/ ] {! i4 {' _0 P g#column3{ float:right; width:40%;}* J q3 Q( ]. o% d; j3 t
.clear{ clear:both;}
% r1 z9 H8 z( q& {% ?; @+ z6 Kfloat定位二
, p) |6 P" k& t. v' Z/ w) u
9 G9 _1 I- _( ~+ zxhtml:1 U0 ~/ c1 b3 u7 |$ _* C
1 n. u+ e7 B! b: F+ K<div id="center" class="column">
6 v! ]4 c+ t5 C: o+ l <h1>This is the main content.</h1>
, D0 M1 f0 N/ \7 c N3 M</div>
. q# t1 c c) k/ z4 R7 r& V<div id="left" class="column">( u- K- a# Q4 G7 |$ h
<h2>This is the left sidebar.</h2>
2 W S4 v1 T$ k p0 I</div>
7 W0 Z; z. ]4 L- W<div id="right" class="column">, c) W. p/ g, ^! E
<h2>This is the right sidebar.</h2>
& H; E0 E5 Z. L3 E( U" E8 }</div>: ~/ e8 u7 z+ u% r) w. e/ w, s
CSS:9 X& C6 J1 `) l3 w
4 Q! W5 n* g. y: U! |" Hbody {margin: 0;padding-left: 200px;padding-right: 190px;min-width: 240px;}
) H d& W: |( r.column {position: relative;float: left;}, m3 V: v7 }6 f# Y
#center {width: 100%;}! f5 S; L4 Y- B# {. `. s) N
#left {width: 180px; right: 240px;margin-left: -100%;}
, S" q/ Y) h M) k/ V9 ?$ F4 U#right {width: 130px;margin-right: -100%;}
: O( L: ` `/ \ @0 e5 c, q兩行三列
. N- }4 g% n% u9 d* @$ P
7 N- Y% X+ w. nxhtml:
7 _( F8 i" `2 G$ l* z( Z2 ?* y1 }' j7 r/ o& Y" a' N% j* ?! w
<div id="header">這裡是頂行</div>
# q% B/ w$ I8 Q# t, \<div id="warp">5 i" G4 Q, p. B: F `
<div id="column">, q& U6 R2 S' c/ e3 `6 _! o
<div id="column1">這裡是第一列</div>4 r( |' H- t% I5 z, I
<div id="column2">這裡是第二列</div>; q0 ~: y7 S* }1 C: I2 a* M
<div class="clear"></div>4 e9 K& e- s. r, {
</div>
. w4 f2 v9 s1 m( }<div id="column3">這裡是第三列</div>, \: i9 F; J0 V+ k; T
<div class="clear"></div>7 ^1 C5 Q1 |, }( f! U$ u
</div>" a. W6 y& y5 C! g
CSS:
3 d* V f$ b( V$ D# L' X: \9 f
* }. S; r0 A' ^#header{width:100%; height:auto;}
7 o7 |/ Y6 @' e; @% ?#wrap{ width:100%; height:auto;}
" y+ r/ t+ l. ~( f4 y( |( P#column{ float:left; width:60%;}- b$ S# \( E1 P( K
#column1{ float:left; width:30%;}
, g% y. L' @6 B#column2{ float:right; width:30%;}9 T* O& a7 C: X. `' [
#column3{ float:right; width:40%;}
( J6 x! A& o& M.clear{ clear:both;}
' p: l( X4 H/ W$ B三行三列
; R' _* b- G+ U T! }& W& D2 Q" @5 H
xhtml:
; @* C! x) X& o( v8 m; Q; T
8 _0 Z1 E# I5 v3 x0 ]<div id="header">這裡是頂行</div>" m6 u4 @! w; O; q
<div id="warp">. d$ ?7 |% y9 D; [# c- s. b
<div id="column">9 X) J0 G/ f2 s" J: o E G
<div id="column1">這裡是第一列</div>
2 p& ~, `6 }, k$ V<div id="column2">這裡是第二列</div>& F" h7 |: Z, F' A3 k
<div class="clear"></div>
8 l7 ^( F& Z& P" _3 E</div>
4 O$ }6 D$ s: @: U8 e# K<div id="column3">這裡是第三列</div>) Q9 v. D4 Y$ G/ S; N9 L Q6 X
<div class="clear"></div>
; t+ `8 ?7 C, l/ [7 }( L</div>1 n4 ~4 s1 H/ p& b# _
<div id="footer">這裡是底部一行</div>
! ~% ~" @: @' _3 N2 n, @7 |' S8 u0 ]CSS:, \3 B' @' b5 c2 F2 s* a
4 [: h r0 R3 p! }# f
#header{width:100%; height:auto;}
3 d& H" q+ I4 s#wrap{ width:100%; height:auto;}$ g; S0 f( N6 W9 U" V
#column{ float:left; width:60%;}
) \' r5 u5 n- t2 R% D#column1{ float:left; width:30%;}
0 X7 b' w3 w& |6 k3 J2 N#column2{ float:right; width:30%;}
, P2 ], Y# N9 A6 C#column3{ float:right; width:40%;}
+ d- A: G: J' U+ J.clear{ clear:both;}
( N- `0 { E8 S. D# F" @#footer{width:100%; height:auto;}
! Z- u, d4 g7 k4 [4 p% }PS:這裡列出的是常用的例子,而非研究之用,對一每個盒子,我都沒有設置margin,padding,boeder等屬性,是因為我個人覺得,含有寬度定位的時候,最好不好用到他們,除非必不得已,因為如果不是這樣的話,解決瀏覽器兼容問題,會讓你頭疼,而且產生一系列CSS代碼,我覺得這樣的效率和效果都不好!
6 L5 R: g4 L0 X: r0 c Z0 B
2 @4 g$ ?1 U$ z" S3.CSS佈局高級技巧
9 M9 ]3 U" d4 I7 M- s; y
, T9 ^$ B3 D' j/ c& Vmargin和padding總是有可能要用到,而產生的問題如何解決呢?由於瀏覽器解釋容器寬度的方法不同:
; L Y! h' T5 l
i6 n" b+ H5 ZIE 6.0 Firefox Opera等是
3 R2 X. k H, ~" l) W% i' u真實寬度=width+padding+border+margin: I+ d; Z" H8 s. D# ]
IE5.X) R# u' Y! E. q3 _. |; n" I) {
真實寬度=width-padding-border-margin4 L0 g: ^& W/ I4 F1 z
7 `5 x, R9 b/ c3 g3 O S
很明顯,第一種下很完美的佈局在第二種情況下後果是很淒慘的!
& Y! x5 `. w& M9 k
$ P3 Z5 [' [5 V9 U解決的方法是 hack
+ T0 C1 J0 ~6 I. P
; n4 C9 ?5 r8 v
% P) F6 |+ S" p1 k, Cdiv.content {
& V, r% i3 v& W9 k- [' ` Twidth:400px; //這個是錯誤的width,所有瀏覽器都讀到了
- X8 s& t5 L9 z/ `6 Y* Fvoice-family: "\"}\""; //IE5.X/win忽略了"\"}\""後的內容
! q& Q4 C+ Y3 V7 Tvoice-family:inherit;
, [2 h& K2 x/ s3 k& J1 u" c! Xwidth:300px; //包括IE6/win在內的部分瀏覽器讀到這句,新的數值(300px)覆蓋掉了舊的
+ N; O4 g! R0 |) o6 ^2 D/ S# q}
( l9 Y4 U, K0 t/ e* Whtml>body .content { //html>body是CSS2的寫法
( g+ n9 D, y( h- q. ywidth:300px; //支持CSS2該寫法的瀏覽器(非IE5)有幸讀到了這一句
8 T9 H1 |7 U( ^! S. K) F}
3 t! t/ P( \4 k2 W$ P$ f- U/ j; b5 u, k; `& W3 w
div.content { ! l1 F7 I& c" c9 |$ H8 t2 o/ D
width:300px !important; //這個是正確的width,大部分支持!important標記的瀏覽器使用這裡的數值: A: j [/ ?' ?7 H
width(空格)/**/:400px; //IE6/win不解析這句,所以IE6/win仍然認為width的值是300px;而IE5.X/win讀到這句,新的數值(400px)覆蓋掉了舊的,因為!important標記對他們不起作用
9 \# _9 [) [, y) S0 q5 m2 V} $ `2 F" g" T: p
html>body .content { //html>body是CSS2的寫法
: g0 ~6 D, ~2 m# s$ K Owidth:300px; //支持CSS2該寫法的瀏覽器有幸讀到了這一句
- d, [ @3 h$ }' x. S' O, }}
4 g3 C% U! {% Q1 i' \具體解釋點擊下面鏈接查看& C y$ Y5 I; i/ P
% l5 S7 |/ \- u3 U- c+ D
www.blueidea.com/tech/site/2006/3170.asp4 D5 t1 r# n7 }) R( Y
www.jluvip.com/blog/article.asp?id=114
0 o4 Q9 d P& N- f- J6 K7 b) W7 i+ x9 I6 q( U
列等高技巧; X. a0 d; X5 X
' r8 t- E( O% b! a$ Z {4 E- {- |
n行n列佈局,每列高度(事先並不能確定哪列的高度)的相同,是每個設計師追求的目標,做法有:背景圖填充、加JS腳本的0 E9 c6 Y! M! a
方法和容器溢出部分隱藏和列的負底邊界和正的內補丁相結合的方法。0 Z1 I# @( |3 W: z- u' M+ {
6 ~& N- [. ?! {3 a7 Q6 r背景圖填充法:% [% l' Q! }) E2 r, T$ K3 {" Y5 v" p
, [5 R/ l& W+ `7 n# txhtml:
5 p. C% R. {$ ~8 y, G+ J( F! L- m. f! @2 @/ Z& X2 U, q/ J7 _
<div id="wrap">
. F9 F" n; k/ w4 T5 u0 c* l7 o" W9 A<div id="column1">這是第一列</div>4 R/ @4 ~6 i5 d# c, X; ~
<div id="column1">這是第二列</div>, O3 ~# R! r2 R7 g
<div class="clear"></div> Z" D/ j: s3 a! W0 x
</div>/ w) L: i8 i2 \ K# l5 P+ h. \
css:
1 v0 X4 _4 Z. d ]4 A4 s7 L0 F1 s+ _& \6 j7 r
#wrap{ width:776px; background:url(bg.gif) repeat-y 300px;}! a, ^ G3 A s7 C0 H" e
#column1{ float:left; width:300px;}
f% a* O w* _4 C; A' L3 c#column2{ float:right; width:476px;}1 p3 }) _# u7 L& E8 M" L- w
.clear{ clear:both;}
" m2 q4 o6 M7 O- D+ u! a4 Q就是將一個npx寬的一張圖片在外部容器縱向重複,定位到兩列交錯的位置縱向重複,在視覺上產生了兩列高度一樣的錯覺) L# m2 B1 u' [
9 Z7 `$ C. ]- _& P2 C( Z& U) x0 H[ 本帖最後由 hailin2442 於 2006-10-5 14:12 編輯 ] |
|