|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。
5 H! K( ^8 b1 e' s. _$ j# S% y8 ^8 N
1.基本语法规范
' P& g9 Q. D" v q% l( S. x% d2 V/ V分析一个典型CSS的语句:
, ~! E8 t1 B$ j( n+ U: B E9 \p {COLOR:#FF0000;BACKGROUND:#FFFFFF}
& t B+ g. z- i0 I+ A4 _其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; ! z4 o9 w$ G8 m8 Y/ f; t$ ^: z
样式声明写在一对大括号"{}"中; c/ R8 l5 M3 N! Z7 @
COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
' o4 X: e6 N+ w- ?( d. R0 A) @) V"#FF0000"和"#FFFFFF"是属性的值(value)。
/ L: j( A# n" M0 j
6 f( I0 j2 B, m) z7 b4 s6 m; O2.颜色值0 H% v. _* [3 |: Z
( U- E7 f# k4 u' c
颜色值可以用RGB值写,例如:
2 E+ l9 P+ j3 U% w, l$ @( \) J+ v5 m/ R: j U! A
) b) e) Q6 ?$ o
,也可以用十六进制写,就象上面例子6 r! W0 H+ T0 o4 ]3 z' ^2 m
8 y! J( u8 a! ^
) W% I* H2 }/ `7 Q
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
( Q" {# p; l+ Z$ ]
: |" P5 R. c& v( ?- E4 W- s3.定义字体
: I; B3 w) n7 A. \+ s8 Y% Vweb标准推荐如下字体定义方法
% u' N d% m% G, t. j- a8 T( K
, h( \3 e3 m G) Q6 I4 Wbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } ! ^0 z& r E# `* k8 y. ~1 S1 R4 O
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
A0 r, n2 X6 p0 ]Lucida Grande字体适合Mac OS X;
6 z y5 K" I( {Verdana字体适合所有的Windows系统;
g) i! S1 T2 ^9 r" _0 N; lLucida适合UNIX用户 . q/ w" ]" ~, p" F0 q& l9 R2 V
"宋体"适合中文简体用户;
/ w6 c! p% g* @3 q# L$ q如果所列出的字体都不能用,则默认的sans-serif字体能保证调用; L# ?- K+ P. i7 y2 W
; @' u0 s+ ^# J5 S/ o! K! W4.群选择器
% G7 x; h: D1 D8 i, ~$ J2 L
: B! {' ]3 Q; H7 f当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
9 j+ g( e. }: M3 J" }8 Q3 ~, n! _9 I {. g
p, td, li { font-size : 12px ; }
8 ^2 _( `, x9 ~: O& c就是给li下面的子元素strong定义一个斜体不加粗的样式0 x) D. G1 s" a# O. d; F' s" P
' A2 E I6 Q2 r, [/ u4 g ^) U6.id选择器* m" H' |3 ^$ Q; O& ^
5 @5 I& t) [( ^5 w3 [
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
/ F' n+ S2 B% S( u0 f& H/ a& u/ w. c
6 P) @+ A+ K) a8 c
( G# }/ R6 [3 K# z然后在样式表里这样定义:
) b/ j! Y5 e) ` P3 n8 T5 X) l5 N7 }3 }' Z) q% I: k$ @
( s: V8 U) ?/ k, B+ }' s6 U/ A
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
! {+ [( }# @3 j- j4 ?其中"menubar"是你自己定义的id名称。注意在前面加"#"号。/ Z" T: \, f6 G5 l+ w' ?
, O: k* b5 g- N2 c+ \id选择器也同样支持派生,例如:
; w# `' w1 S1 m. b) Q, U#menubar p { text-align : right; margin-top : 10px; }
) P6 k4 d- T& X" I这个方法主要用来定义层和那些比较复杂,有多个派生的元素。+ R, K. f& x$ }9 ?- k8 H9 A
9 \/ g3 }6 @/ z N: V k- N# H6.类别选择器
" N! f x) E5 }% c# h. a: X5 C% H' x7 g" Z7 j, A# F3 b
在CSS里用一个点开头表示类别选择器定义,例如:9 _: u+ s5 `! l; l" \" `
.14px {color : #f60 ;font-size:14px ;} * P) a5 e. k7 n/ V0 q
3 Y1 o/ y8 S* l0 g; A3 }8 T
在页面中,用class="类别名"的方法调用:
$ ]. s, d c/ h<span class="14px">14px大小的字体</span> 3 C. B* b7 D% Q& X
/ p3 m- G' B: }8 ] m
这个方法比较简单灵活,可以随时根据页面需要新建和删除。
/ F- W8 n2 @0 ^" P7 o V6 }+ {/ S
7.定义链接的样式
7 C, r, a5 I: n: b6 }0 q7 Y3 i4 t% g2 hCSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:/ Z2 D) p c0 K
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}& N" w9 D% L( `0 m2 H' P
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
0 } e' W0 y# |a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
. k J6 W# b9 Z8 v! T) Ra:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
: R6 b' E9 n1 W' s% }% W* I
+ Y% j' m. `* g以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|