|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。% W' v( `/ O" R4 D3 s
, m, f* m5 y& b4 \- o' @
1.基本语法规范# D+ L+ Z4 f3 j; m7 J; c9 R8 [
分析一个典型CSS的语句:
# e9 @8 b9 v; H7 X4 {% a- Ap {COLOR:#FF0000;BACKGROUND:#FFFFFF} & K' u* I9 u6 Z
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; 5 @! T x6 F9 T' D7 Z& C
样式声明写在一对大括号"{}"中; - p# _* T. I2 D& }/ g/ f
COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; $ |5 x! H* `3 V% t
"#FF0000"和"#FFFFFF"是属性的值(value)。
- m+ t) E: G! E+ l4 X/ q: p+ ~1 J, v6 k
2.颜色值. b" e2 F" _9 n f. }
4 }: `1 L4 y7 Z/ k0 P$ r8 G颜色值可以用RGB值写,例如:7 ]7 U* V; n9 K
2 _) U! v. S, o1 ?
/ X$ H1 d3 m* J( z. M,也可以用十六进制写,就象上面例子
: z W( p6 C/ B* M. U
! a( b9 o* w+ U3 @1 }. b7 Q' i& |0 {9 Q3 o# ]7 w
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
W$ }! _9 r6 V. Z1 I, b$ Z: A9 N+ \" i8 x, ^, X* |
3.定义字体
1 ~( F- \* J; Q2 [4 e* wweb标准推荐如下字体定义方法4 f8 Y5 Y( S! q9 R
. W' [; @1 J- O0 C& i" L& p
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
* x3 }; B/ Y2 L8 S. w) F字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; " F( D% z6 Z/ _6 v3 }: a5 z
Lucida Grande字体适合Mac OS X; ' T+ U' q1 K$ t, {; e* }
Verdana字体适合所有的Windows系统;
2 U9 V" s$ s$ p+ RLucida适合UNIX用户 ! `* |9 j: ]$ A
"宋体"适合中文简体用户; 5 \& I/ ~ o3 l& k
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;& o- M8 @/ u* B0 W6 t( A
: h+ i* s% ~8 y7 Z4.群选择器, M$ d! P9 E) x
% J* p( l# S! ~ T4 ?" Y当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:1 P# }7 O$ v3 t( _# ]/ _
+ C& I$ O0 R+ Q* y x9 X/ e p, td, li { font-size : 12px ; }
- R, G1 M( Z" p8 a. F0 u' ?就是给li下面的子元素strong定义一个斜体不加粗的样式& i2 g5 b0 v0 J6 @$ p6 B6 f/ d7 X! K
% T* Z6 c1 ^0 f" }8 f7 B0 O C; y" X6.id选择器
5 c5 x' `) T) L3 ^) u8 O: E0 X$ H6 w3 s y. \; c
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层) ]' J, N7 e+ K5 q) L g
0 d( U4 \* w$ T2 g; {
2 [9 |) l7 L! o0 n1 l/ u" Z然后在样式表里这样定义:( V6 v! I6 U! n
0 ?+ e" n' Q% s' x+ w, M3 t$ |% y, j! R5 P2 x" C% A
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
d8 g$ l% w5 c# C# m5 |其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
) K) M3 A8 p$ p0 O* _8 i" ]- q$ L; F
id选择器也同样支持派生,例如:) N) U, t& z$ t. [* c
#menubar p { text-align : right; margin-top : 10px; } # u- o; a% b1 y- J9 g4 S/ s' y, m
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。) `! M4 G& h; [' q
1 `! a3 z6 a |- _. I. t2 H: ]6.类别选择器; W: @5 c; u( I F1 Z
+ Z1 {9 I J8 _; d0 `在CSS里用一个点开头表示类别选择器定义,例如:
" O" u! j9 E/ G: J3 I.14px {color : #f60 ;font-size:14px ;}
' e2 r* h- C& J; j8 @
; Y" `) z9 g, K在页面中,用class="类别名"的方法调用:5 D! @) O& f9 H, _+ F* y
<span class="14px">14px大小的字体</span>
9 Z4 o2 G- | H& S% a5 i6 ?/ Q
: K% o& y b- v1 f2 D9 H- h! F" G这个方法比较简单灵活,可以随时根据页面需要新建和删除。* i m$ V( A8 R5 V: w- j
' P' R# g9 J$ t, c8 [( k$ _! P% D% t9 _
7.定义链接的样式- t" G! T% h* p& w
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
7 ~2 X( @: Q$ \2 La:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}% p8 D( f: b0 B/ i; ?0 {% g
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
3 H5 a$ \6 I# a3 ka:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}0 F2 U# d% D" w4 `7 L
a:active {font-weight : bold ;text-decoration : none ;color : #90 ;} 1 b- o. _3 _1 M5 J- W& L
2 ~4 k" V9 ~; o
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|