|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。
1 `2 `/ m$ l' Y# i7 }* o% b" D( F. b% }
1.基本语法规范
! n, o# v& e C& O+ S$ N" v分析一个典型CSS的语句:9 T D( h* g3 h' w
p {COLOR:#FF0000;BACKGROUND:#FFFFFF} ! T* X* o- o5 ^; o
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; 6 f M4 \+ H0 U
样式声明写在一对大括号"{}"中;
3 `' [, F$ a6 j( y, T) D4 T! @COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; ! B! C K4 r2 m2 R* e6 z9 Y3 L$ ?
"#FF0000"和"#FFFFFF"是属性的值(value)。
- u. Z2 z( q9 \* j: C5 f1 C6 S# v" o' r) Y* ]. p6 P5 X
2.颜色值+ O a, G$ p- ]" l4 j( m/ S
9 B1 e8 L8 E4 A8 h7 g' E颜色值可以用RGB值写,例如:; `& F& `, _5 g
) T) k4 B; Y, x4 c+ D+ B' C
4 q+ v0 Z7 \' G0 }5 W0 N,也可以用十六进制写,就象上面例子
. b* w6 Z9 F% D8 ?# J! I% L7 E9 T* g4 e, P4 N+ u# s
& |+ r3 N. L# q/ c; U# Y如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。4 t) v/ F1 |4 N1 p. j
5 _8 f5 S( a- A0 s0 ~4 c7 F
3.定义字体+ E/ B/ h1 y: ]2 F$ t
web标准推荐如下字体定义方法- |& {% h4 E* d; @0 \$ `
2 w3 u6 u1 i8 g; abody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } : x5 f: ]4 x' y: t8 N% ~ j
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; ; C# K0 c* p; x. s/ F' M
Lucida Grande字体适合Mac OS X;
' q6 s4 [% x7 @6 d- I8 c; E( LVerdana字体适合所有的Windows系统; ) b3 n0 \! a2 r3 J
Lucida适合UNIX用户
2 G* d4 x: O0 r; R0 A+ h"宋体"适合中文简体用户;
8 P7 ^# B8 _4 n4 K1 H6 f/ o8 ?如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
^. {# l% U' O0 G# k
& N2 I% X0 h, h- x* M6 B4.群选择器
9 s6 i3 T) z D, Y) R, C1 |6 D* A, u0 e
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
: j: y0 p3 {3 C' o+ t }" T: b9 x. l+ A+ p
p, td, li { font-size : 12px ; } & l/ o! W& J. q4 R; Z% u5 K% I
就是给li下面的子元素strong定义一个斜体不加粗的样式4 u2 B2 a) `; B
* s+ f( c; U6 e8 x3 T. {9 u
6.id选择器6 S% s8 U5 w" t
! r. E2 u1 z) }. I
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
) X* M2 d! B0 X% \2 |9 ^3 O
8 p& y7 S: Z/ c$ Y
4 Q+ H% T* K, M1 @然后在样式表里这样定义:% S+ @1 I( C" v/ T
, _* N' g: d. H# k" z
+ e( N0 j h1 y/ I9 q* j#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
7 b. D6 ^0 R! N1 r其中"menubar"是你自己定义的id名称。注意在前面加"#"号。3 i6 y! @$ v& B0 s* I3 o# o) D4 d" \
6 X5 O, d( ~7 c! U- d% K$ p M
id选择器也同样支持派生,例如:: w4 g$ Y( ^8 \: N
#menubar p { text-align : right; margin-top : 10px; }
/ {! g4 H% K: ?9 r& d这个方法主要用来定义层和那些比较复杂,有多个派生的元素。% L- O0 f0 `& ]- w1 V+ j5 |$ D
7 B8 f5 b8 _- M) z* m6.类别选择器( A8 U1 s. T2 G+ A- W
( [& z6 p6 `0 m, U4 g在CSS里用一个点开头表示类别选择器定义,例如:
6 L$ ?& R S; ^7 l.14px {color : #f60 ;font-size:14px ;}
: Y4 B1 G) ^; c% Q1 e4 T1 }! [& K4 W$ p5 x! K
在页面中,用class="类别名"的方法调用:
8 ?; u0 l/ A1 ]1 ^7 K4 k5 \<span class="14px">14px大小的字体</span> # W' _1 C6 }& y9 F# p/ l1 u
* ~$ ?0 _1 K/ [) K4 x这个方法比较简单灵活,可以随时根据页面需要新建和删除。# [) s/ m: y: X- u4 H
, ?% f1 \" i7 p3 c8 }) L
7.定义链接的样式
+ |$ r' o( T) g4 [CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
7 k0 U4 v# Z9 C& pa:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}0 Z- T) i6 L0 @% ~
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}$ X# M% L- C" q
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
2 Z0 g) U- V3 g+ Da:active {font-weight : bold ;text-decoration : none ;color : #90 ;} 3 o/ c; e! W2 T n
. y- F$ X; B2 z+ W0 c以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|