|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。& v* E. `2 k0 q4 K# P7 p8 y0 l
- f1 z4 m* W' g- p
1.基本语法规范
- |4 T( r/ b) {" s' s8 N2 c分析一个典型CSS的语句:( N% Y( c. |8 ~+ D
p {COLOR:#FF0000;BACKGROUND:#FFFFFF}
. N; ~2 v$ @1 B, D: \& b/ A其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
3 }+ d' p. p% c! E6 D% X$ t2 \样式声明写在一对大括号"{}"中;
4 d# q! V6 }/ r. ]2 O- `7 z: VCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; 1 p/ s; W' X4 L/ G( N# K
"#FF0000"和"#FFFFFF"是属性的值(value)。
) z2 Y* n# G! Q6 m% S9 P2 z. j; x) _: R6 z; D' Q2 Z
2.颜色值
8 Q3 W' A9 S% ~& n3 @, ~0 M6 |5 g. U! `/ H- U
颜色值可以用RGB值写,例如:
: t! N4 p. A( N) \: |8 |2 d9 Z8 Q
9 d4 M* K$ f* ~ w' C3 Y. l
,也可以用十六进制写,就象上面例子# T- A! C/ }; P% Y. B a
. r, m5 u5 ?/ q+ K7 w$ {9 a! ^3 i
" v: |/ Y; V: x" Z. w/ L如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
3 R& q u! G; z% \& h$ x; l* M; Z
( [; V# V n( Z3 x7 A) `3.定义字体 J2 S9 R6 U3 r1 n) }- G' s( h
web标准推荐如下字体定义方法: J7 |9 Z; h( R/ q7 X
; r% v( O0 L$ z- j- F
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
; Q( T& R' q$ H$ j; P; d& f# x0 L字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
+ o2 R7 S" s) K0 m! u1 G6 \1 rLucida Grande字体适合Mac OS X; S; A, \2 A9 u# u# V! j
Verdana字体适合所有的Windows系统;
6 A" s7 n, m2 n1 |) HLucida适合UNIX用户 . }9 G) s2 U! x X7 M( g2 n
"宋体"适合中文简体用户; ( a2 @, W: B# I* e+ }
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;5 G7 o9 ~- v7 G0 v* ]
9 M4 i7 Y" J! w0 A# l- V) t( |5 p
4.群选择器
$ x) f. ]' b; y. O
5 K: _' }( w% ], @2 s+ X6 K当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:. x% i& e1 w/ P$ h$ T" `
' `+ j/ P: A! r- G/ b p, td, li { font-size : 12px ; } $ S+ Q& o* Q. ~3 e% V; j0 b
就是给li下面的子元素strong定义一个斜体不加粗的样式: H9 R$ @% b" t0 V$ ~
$ c. |$ \/ q+ t. ?, W, i
6.id选择器4 i; b5 ?$ Y; ]1 `& j0 U7 T
* l3 ]3 [! v& a0 F/ p( R2 P V用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层4 _ G/ s. n. M2 G
5 O+ d/ G& N6 y6 I+ V; i+ }; \" [! t* N- L: x: i& L! R% Y. {
然后在样式表里这样定义:/ q# k8 N6 J$ B( m9 |
2 y r& G# {/ i/ j1 R3 k2 ?( M6 ?
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
5 T/ X9 P6 j3 J! j其中"menubar"是你自己定义的id名称。注意在前面加"#"号。$ l4 D$ q6 o$ b. D7 {& A" l8 [5 b
$ T1 q8 q4 {& H( W6 Vid选择器也同样支持派生,例如:
) Q" }9 _* U7 J# {#menubar p { text-align : right; margin-top : 10px; } % a! }" B) A3 `1 x1 T7 u* p
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
$ i; i4 B: E% O( M
" `8 A5 u: Y9 e/ ~$ l6.类别选择器
" B( S9 z: ]. }" H& g1 h* o& I2 j/ w: ~+ _
在CSS里用一个点开头表示类别选择器定义,例如:' {' @$ X9 k9 H+ B0 Z. G% Q5 E5 l
.14px {color : #f60 ;font-size:14px ;}
( ? {7 K. v. `$ m/ I7 x1 o3 ^( E
在页面中,用class="类别名"的方法调用:
$ n- j9 v7 n+ f) K9 h<span class="14px">14px大小的字体</span>
0 X/ p. `; X3 @2 V, b. g/ y9 u
) [! c9 T5 |* I8 S2 _ Q" f这个方法比较简单灵活,可以随时根据页面需要新建和删除。
" a/ B' W2 Y! V; m
$ j* r5 W) c2 ~7.定义链接的样式
7 V1 q" L3 k2 M" P$ [( ^CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
& J2 I& m. K! G& B' ba:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
) U! N: \3 O3 X0 [3 `) {a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}/ J' n# T8 H7 _
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}# z l/ I6 m$ a+ J
a:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
4 ]8 x) `5 a/ h, S T3 ^1 M2 a2 w0 T1 g
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|