|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。
) f, s* L( X+ n) i, y! y3 w2 U. G) T+ m X2 I+ \% K
1.基本语法规范
, |: b/ h# O: j6 l; w! |6 k7 H分析一个典型CSS的语句:
7 N+ `2 U+ y/ a+ ~! j# Y8 i3 }p {COLOR:#FF0000;BACKGROUND:#FFFFFF} ) l* ?- v( s* A+ \
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; ! f# C9 d6 _* _7 K. X
样式声明写在一对大括号"{}"中; + r; v4 t/ p. t7 _$ N
COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; / r- B; |* A3 T. N8 s
"#FF0000"和"#FFFFFF"是属性的值(value)。, G& O/ k8 O# c
: g# |6 B; w$ n7 f
2.颜色值# V4 l3 @( f' }: }# I
# N D$ d, o- I6 c- j7 ~
颜色值可以用RGB值写,例如:
+ A; u) F0 N* Y2 K3 @( d
6 C: I; Z$ ]# j. y; T
0 g: x$ U4 S+ s3 ~: `* p1 O/ p,也可以用十六进制写,就象上面例子; h$ r Y. b7 m% C7 \7 |) @ _
& Z) |5 Y) [0 p+ c, G- {
9 E' v6 m5 Y9 b2 H( V! f
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
% W/ x4 W& H0 R f R; k/ e6 i, q
1 f, ?4 Y0 ]* b( N3.定义字体4 u) M- F/ h3 p6 G7 [4 M* N& ?! j
web标准推荐如下字体定义方法
, v4 G0 @$ R% [0 W; V* g. y# b; _. m* r% f+ G
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
* g5 }. C k N7 n# Z) _" u) k$ s字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; 4 e$ y* m: @: Q2 {* p6 r5 }
Lucida Grande字体适合Mac OS X;
, A: R, T8 @: j4 q2 {" x& SVerdana字体适合所有的Windows系统;
+ T- c; I3 H( G0 S9 TLucida适合UNIX用户
- `" K" Q; i9 P7 s3 A"宋体"适合中文简体用户;
" Z8 J# @; ]$ a$ `- K: H4 p# F7 z如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
4 ?' _# @( h- G( [" R( V' B$ U1 G6 l# S2 Z0 t( }, y# y& |( K" k+ }
4.群选择器3 R1 v- e) M& Z5 J
+ f& v" B) x. O( l% `当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:+ |# e6 b8 e* S+ L; S4 _" g, K8 D
6 M8 x. K' d* l9 t% u
p, td, li { font-size : 12px ; } - c% W6 D7 f2 X. D6 O
就是给li下面的子元素strong定义一个斜体不加粗的样式
" |* w# B% y+ l& c$ m( U. ?7 r4 H [" z$ I
6.id选择器
: h" k3 J7 z" t3 F
. f% f2 ]1 R0 O( t! W& ? @用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层3 O0 E# f) m$ { D1 K, q
6 j9 c6 ^. X. X/ Y O: I1 l4 ?
6 T3 _& y/ E& b% o& }, w
然后在样式表里这样定义:) h* q( r. r' m6 Q
' l+ E& C }, [
$ s8 f! l6 J! @( |9 e, z#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;} - O- L+ c# P6 q6 }) e
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
4 ^# k: u# z7 {/ g
/ O2 D5 Z$ s8 E2 q5 ~3 cid选择器也同样支持派生,例如:
' q* T3 g6 [" |#menubar p { text-align : right; margin-top : 10px; }
b$ i" h" Y2 u3 C6 V! h这个方法主要用来定义层和那些比较复杂,有多个派生的元素。7 A# ]: c1 \- w! E: h( L, A
' J, S" n/ b3 A9 G) r. f2 h6.类别选择器! H \1 o$ B7 _* e
& [0 @, E# t* I8 ]) v' i& A! |在CSS里用一个点开头表示类别选择器定义,例如:
7 ~- }4 r. Z$ H5 }8 H) Z4 W" u.14px {color : #f60 ;font-size:14px ;}
0 L) p# @. U1 G: J0 o0 c7 k& n8 F7 y3 }8 L8 o7 C' _. V, A
在页面中,用class="类别名"的方法调用:7 k5 J8 S5 A1 [8 _$ L3 i
<span class="14px">14px大小的字体</span>
1 r l: P: S% y4 i4 ^4 }# S v) q+ z; D) L0 I6 Y
这个方法比较简单灵活,可以随时根据页面需要新建和删除。 B0 r; q8 Z5 A# l) {+ n# \/ n
4 J/ D& J2 W8 {- ?% M' R
7.定义链接的样式
0 O5 v7 a; P9 v0 l6 J& x! jCSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:! R* y8 Z% O- l) o
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
1 X0 t7 O* g; X O- Ca:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}0 }! ^) x& s9 N7 k: E
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
3 p3 U& [; n3 x" b( sa:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
0 y& ? b" T3 a6 O& c7 f4 j: u4 @; u% z1 R, X7 m5 t+ [' H7 g$ q
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|