|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。9 q) V) v' L! _
) ?0 ^9 w. m9 f2 B
1.基本语法规范" B- j+ l5 Z+ Q' j
分析一个典型CSS的语句:
0 I5 r$ y! q0 z" j1 C* N+ F, E7 Hp {COLOR:#FF0000;BACKGROUND:#FFFFFF} ( j: Z( P' k0 [; e3 g: F
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
, n7 T# v/ P5 [9 p样式声明写在一对大括号"{}"中;
' y. m+ l9 R8 ~, D$ P0 b# S+ oCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; n6 X( J$ g: W( K I0 V
"#FF0000"和"#FFFFFF"是属性的值(value)。
% D$ W& r" \$ ^+ n& ?2 n0 R3 t6 y& P
" b) C$ O3 N) _" X; x2.颜色值" k. ~/ n' s2 c2 S ^& ^4 |/ T
N* `( |( U- o2 k- u+ g, ]% V
颜色值可以用RGB值写,例如:( h2 O+ z! z# {8 k' ^" a
1 z7 G: \/ D" q6 B' X# A
- [, ` ]' e5 z,也可以用十六进制写,就象上面例子! T- u. @! Q A1 T$ Y* F
. s4 H% d, y5 u" r4 L* _
* t E% ~( B2 @5 f* h+ H如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
; w! B! t( w' b. z/ M! n9 O# x0 \' O: D/ Y- S, ^8 M: G
3.定义字体' L9 s* m' m% O7 B" T5 E( E5 Z
web标准推荐如下字体定义方法+ L2 }! b" v' l# k; A( ~
9 ^+ C; }# g+ Pbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } 0 ~+ J3 `& u: ^7 w i
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
9 X6 V; V7 J V d+ aLucida Grande字体适合Mac OS X; # Y0 b/ u' q" i, t! d
Verdana字体适合所有的Windows系统;
7 ]; t4 w7 W, C* cLucida适合UNIX用户 6 |/ ~% v* ~- K* e) R
"宋体"适合中文简体用户;
; p# s/ t+ @4 L1 Q( J3 \8 V如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;5 q9 T1 E5 w9 \# r$ n- x
. W+ [ s1 M- l. y9 b" ]4.群选择器' O% J: x2 G$ `5 q" s
* u: j& v: Y: ]) j
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
) p( k' c& L: x* s, l! E+ C, S9 ]- G. Z# c7 p
p, td, li { font-size : 12px ; } - g" ~0 R/ m9 a4 k, B' Z
就是给li下面的子元素strong定义一个斜体不加粗的样式
' K( K# |1 m' H T) ~: N4 A
9 K' ~; c0 W8 ~7 s# \4 } s0 ?2 G; d# M6.id选择器
* ] Q* k+ c# ?% y
# c* V3 G( o& N; `$ Z用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
7 {! c4 S6 M; k* l. v) N4 s4 I/ W" V {& e, q
! L1 p+ y+ t- ~1 y# X+ y$ q
然后在样式表里这样定义:
) n8 \+ p9 d p7 S$ b4 S" }9 h
( h+ H: B+ F" o/ t* B1 [/ f- u5 q% X/ k! M( Z
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;} ! z5 Y- o3 w' d
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。0 [6 D3 a- O/ I1 _/ C
0 \' w3 p' G( Q9 G: V3 J8 J
id选择器也同样支持派生,例如:
- X- i7 O' r9 |! q s+ o! C#menubar p { text-align : right; margin-top : 10px; } " V, t& a( V! }; g. y1 B6 O+ o3 \" k
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
: l9 F1 r# c7 B2 A- ~; o2 m# S" K! L
6.类别选择器" I* m& A* x5 j
2 s- @6 {# _6 a4 X# |. `在CSS里用一个点开头表示类别选择器定义,例如:
& E; E0 X. A7 r# ?.14px {color : #f60 ;font-size:14px ;}
8 d' j; t* J2 z3 ^( m' S2 | J3 p0 [6 A, J# I( ~+ f6 g2 G
在页面中,用class="类别名"的方法调用:. D6 U& d4 z# G
<span class="14px">14px大小的字体</span>
- R' g0 F" z, h' [+ Y: ]0 |% F8 u# i, \% h
这个方法比较简单灵活,可以随时根据页面需要新建和删除。& v& B- U* L, g- z% s$ m
2 `# @+ x9 \4 L) ~3 K7.定义链接的样式
) r" O: m! l& Z/ jCSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
( ~3 L# q0 h8 C0 Ua:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}+ K2 K) V+ J5 d/ n+ m
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
\- D6 ]& ?* b o6 ta:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
' v& l- F8 j+ ^) Q0 P' w4 P2 [a:active {font-weight : bold ;text-decoration : none ;color : #90 ;} & M: B2 I7 z( o$ H% w; h! H
1 @4 E5 N% l5 D以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|