|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。% R* j0 c' d( w& b7 x
9 ^7 ~3 a9 C0 [. ~& A$ C0 T
1.基本语法规范6 Z2 A2 T/ \2 F6 E
分析一个典型CSS的语句:
7 u0 X `# }$ a3 i6 r- Xp {COLOR:#FF0000;BACKGROUND:#FFFFFF} 2 l. \3 `( g. o. D
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
$ {& N' x! X1 A) K5 e. `+ m样式声明写在一对大括号"{}"中;
1 f+ \. X$ O# G9 zCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; 2 o9 s& }+ `9 o7 M+ M8 n: U' D
"#FF0000"和"#FFFFFF"是属性的值(value)。
( H- I/ \7 ^1 p4 j5 E9 r: J; r$ B$ b9 d" \7 N4 s- N
2.颜色值) h5 F' N6 g' T3 B4 D3 B
2 C- n5 }- y% Y# B1 u& N颜色值可以用RGB值写,例如:
$ Y: b7 {1 I8 X& k: [1 j- C( c7 ~$ t7 J! o
7 v" W0 K0 \; Q+ p$ n; Y6 S,也可以用十六进制写,就象上面例子
. \ v4 Y, v- ~6 |& G: p( }) \# X
P+ V/ b$ A: L$ w: ?% k, o3 P2 g I- j0 z' y1 Q. k$ \" A. i
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。- I9 c- ]$ _6 n8 A( B3 [, _
/ g8 S; F: S/ a! Z5 q# W4 \4 u' T2 G
3.定义字体$ b9 A$ Q. C( ~
web标准推荐如下字体定义方法. c j V: M+ I9 R( z* c
: v2 W, ?6 ~# `7 X; S5 q$ _
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
" X' s& a0 V4 P3 p# `字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
- g6 ?4 ]8 z$ `Lucida Grande字体适合Mac OS X; - e# W6 I/ b! M3 U3 M4 y5 Q; @; m
Verdana字体适合所有的Windows系统; # `9 l- e7 |4 ?: w. y
Lucida适合UNIX用户
2 r5 D5 ~8 X+ _$ k' b"宋体"适合中文简体用户; - _. @- J7 z6 L4 ^
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;& b( u f& g8 T
) ~+ y6 Q. A! k$ I& a( V4.群选择器
% @; ~- E a8 `. p, Y R3 M& ^
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:( F0 h: v6 m4 |( L5 @- f, N; _
& d) Y* u% o5 l% K, `
p, td, li { font-size : 12px ; }
5 |7 }" n" }: x! Y2 O就是给li下面的子元素strong定义一个斜体不加粗的样式
8 a, S Y/ y* i0 N% p
$ h% Q Q( Z$ d* x! Q6.id选择器0 v1 o9 z" p0 `' ?& b4 L z% R) U
, {3 F1 z4 t# X% Z4 X1 @
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
2 S* p0 q- P( {
F: }8 o. y& G' W1 O
* S8 g' C- A3 _# @然后在样式表里这样定义:0 X6 k' T6 q+ i# B
+ G6 g( ~4 d6 `" @3 ]4 I$ d0 ]9 q. r! x4 r1 q$ y8 n j
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
, F( ]2 w c* L3 c+ D) Y其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
5 w% V4 ^3 `- `8 j
8 q p6 D3 |0 t. o4 Gid选择器也同样支持派生,例如:
- n/ {* i) c; D( l- j+ r#menubar p { text-align : right; margin-top : 10px; }
+ E+ [5 i) o+ y5 Q( m这个方法主要用来定义层和那些比较复杂,有多个派生的元素。7 a) c- n/ ]/ W/ Y* z+ R
$ R6 P, h, [# X
6.类别选择器5 R) H: p: |- x9 y* X1 `/ l9 N
0 h+ q0 k" H4 h S) {) i& f$ f在CSS里用一个点开头表示类别选择器定义,例如:
5 O- J+ _( t& p+ R$ l9 }4 A- i.14px {color : #f60 ;font-size:14px ;}
- L8 A ]; _2 ~5 v9 e# X0 b6 P* b) O i" }6 V& ]/ ?. W H
在页面中,用class="类别名"的方法调用:
( \1 |0 P, M p4 @- d<span class="14px">14px大小的字体</span> ! g" b1 n& G9 w2 t: P: j' [6 k4 s3 C
( X7 G% n: v1 R- I) w2 G这个方法比较简单灵活,可以随时根据页面需要新建和删除。
0 `3 y7 @+ H' I0 K/ {0 {! E- H+ ?( J( L; u) c4 t8 W% l$ O
7.定义链接的样式- m; N$ c9 o# {+ v: X- h
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:2 @' u- I2 c9 s0 {+ r
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}% t. i; r% Q. O& x% h& l( |
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
- Z) Z" U, Y' ?+ ?" ka:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
# \2 f4 J9 X$ S5 F. s0 h0 Z5 s8 Ja:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
]1 K" D: B7 L- x3 h: i9 O" }9 O' r H8 P: r" q1 T- G
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|