|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。
4 w4 h+ p+ s8 f9 d6 x2 a5 H
! D# G" Y$ d% ~/ e( p$ ~1.基本语法规范7 i1 D% \: |2 }: \3 ]7 {+ x
分析一个典型CSS的语句:
) } ~/ Y3 h3 @. W8 R5 Dp {COLOR:#FF0000;BACKGROUND:#FFFFFF}
6 H2 V7 j( d# l6 {$ I, q/ f: s& \6 Q其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
6 K& b3 s9 Q/ F0 s样式声明写在一对大括号"{}"中;
. O' b* G4 Q- o1 ~/ Q$ v6 ~6 zCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; 4 z- |% a5 [ L, }& R' E3 p
"#FF0000"和"#FFFFFF"是属性的值(value)。
7 {! j/ ]# a) X: _: g) J
5 R* b2 @) p" w9 G: \. ~: W- K2.颜色值9 h5 U/ a- \7 o5 [6 g4 ~
/ A) j9 S2 F" H2 S* L3 Z颜色值可以用RGB值写,例如:0 b" g3 R4 [. [/ A' h; k
; ]) j) I7 l5 N. z# J
9 `6 A' n$ O4 F/ O3 h,也可以用十六进制写,就象上面例子0 l7 H2 O2 M, C. y. D5 R# d2 y
2 c, O- B- _7 K1 ~+ a. M. A1 F; m1 f8 M* k2 ?9 R
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
& b1 U$ T) I9 o4 n4 n" h3 Y
8 d+ D" q2 B: C) g$ i: l3.定义字体% N, e' T; q8 |1 {9 f# } Q
web标准推荐如下字体定义方法& J4 h: f' N/ I( W; c0 P: T& U- \: R
- p+ H5 g: T! \) f9 A- c0 q. ]0 |body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } ) w% F+ V0 i B( j; u( w9 Q
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; & v7 ^' @/ y; O; u( j
Lucida Grande字体适合Mac OS X; : E. J0 X! @7 I+ J/ [
Verdana字体适合所有的Windows系统;
* c: H5 H# b t, qLucida适合UNIX用户 5 T! Y; m- u2 b% ?
"宋体"适合中文简体用户;
: C, e( A" z: k ^! Z1 r+ Z" W7 z c如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;, A7 ^1 z5 C3 \# a7 g
5 h* v3 \ c/ S: x9 R/ q
4.群选择器
+ Q' h# z; P3 X' s/ a2 {& ^& o2 e3 V) t% K5 Y
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
' f4 W2 A3 ~3 `8 f) x6 ~* K. b( q8 h
p, td, li { font-size : 12px ; } 2 X( f7 _7 H$ ^" A, j# `1 n# i
就是给li下面的子元素strong定义一个斜体不加粗的样式
& V8 `( d4 |4 ~3 Q& B8 U5 A, |* v% O# h$ [
6.id选择器 r; G" D1 }5 \. u! R
" r) w/ B. v9 h2 h% E用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
/ _9 v/ S2 D% @; u4 y5 R! \" G4 U) t; u, P: a5 H& ^
6 g: v+ g% s; o9 |! k) o1 j
然后在样式表里这样定义:
7 R; e2 t* [# l" N4 m
3 n& i! z4 V' X: h' z+ x1 I
" L/ c* ]+ n, r+ U# l#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;} - r- v& p% n6 |) n
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。: r7 y! x0 H/ z
; R4 L7 u! o2 a, jid选择器也同样支持派生,例如:
- X [1 F/ x0 d2 [9 p! Z#menubar p { text-align : right; margin-top : 10px; }
- l. Z0 ?6 k: n0 P这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
/ f% g% N& t3 Q c) Z, K4 p3 d0 D& d$ z
! y1 M7 p* O: h6.类别选择器
6 X+ y- |' p5 z4 u1 v. y1 t' m* q1 _, T# c/ o+ z
在CSS里用一个点开头表示类别选择器定义,例如:4 z7 z2 n' _6 S3 m: Z
.14px {color : #f60 ;font-size:14px ;} ) F1 L& J6 V& r2 p4 P, }4 I3 H: a
" ^8 W6 @' q( F" J) q
在页面中,用class="类别名"的方法调用:# A# y8 H2 k1 o6 k% y3 O3 K
<span class="14px">14px大小的字体</span>
& |9 E. N* V" s& ?0 Z0 C: t2 K+ Z' \/ m; W6 t T) z
这个方法比较简单灵活,可以随时根据页面需要新建和删除。
) u, F Y; H, f& X" B
" ~9 v6 F: S7 C7 i! g+ P9 _; U7.定义链接的样式% ]' i" \8 a ?) g! Z6 j
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:. A3 h m: D& X7 e' D; f+ t2 z
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
/ w6 z! U7 R0 Ma:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
$ C4 F/ D$ r+ K3 Ta:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
; ~1 E9 {# ` ^2 }, O! x. P: Aa:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
& |0 ^: u& T# f4 m0 _* ]" H2 U" R
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|