|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。# r; u# _# O {# I L% s P9 C
1 ^% P9 P+ V; P& a" w c
1.基本语法规范
9 i/ X3 h) `/ i2 b/ d: D( U- U4 Y" ~分析一个典型CSS的语句:' | ^0 n4 E& |
p {COLOR:#FF0000;BACKGROUND:#FFFFFF} / L# f6 D* s# z2 ?3 h/ |5 h* E! ]6 \
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
5 I; V+ D! H) K% \1 R* m样式声明写在一对大括号"{}"中; } A ^7 B- A6 B- f
COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
, [" `2 J5 L' E" a3 v3 f/ X$ y$ H"#FF0000"和"#FFFFFF"是属性的值(value)。5 e4 V4 q$ v' @0 J4 C" }
! c7 A' ^; n. s& k1 ~' b
2.颜色值
# \1 X8 h5 C8 Y; `7 A" u7 v# ], |, R5 \! Y$ Y
颜色值可以用RGB值写,例如:, K; z8 Z0 R9 a" _2 q3 b
* I( D% l0 ]3 m4 x! ?. Y) _$ _0 G0 m3 C* q
,也可以用十六进制写,就象上面例子0 Y J9 t0 K C
; ^# s$ @1 q* n' l
$ q. |1 |2 U# _6 G如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
, S. m- V& L2 t0 r
# ^6 b$ T+ O+ Z1 E; D3.定义字体
# U9 q, G7 a: cweb标准推荐如下字体定义方法3 l8 \1 y: R- ~# L4 q4 ?5 w O
+ q* V; @- K$ F; {0 O U) Dbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } & I+ Y/ ^2 `; H' r: ]
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
" E4 a! ]2 B3 B; e# X! v8 N8 o: ILucida Grande字体适合Mac OS X;
# c, P$ s3 u, _9 Y" }8 }8 @' \Verdana字体适合所有的Windows系统; ! d4 Y" { U: z% V
Lucida适合UNIX用户 / n; V& Q5 V+ J1 V+ F; ]2 }
"宋体"适合中文简体用户;
" {1 d/ M9 B0 p; a& E如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
# w/ l8 u9 s8 I( ~
( r4 A1 x4 v) P- Q* f. M4.群选择器* s; ]; o! }5 n4 P* N
) j! h" m5 \8 |: B0 ?
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
* Y5 ]% `# i7 ?* j& v2 h0 j) }7 U! X
: O5 D4 \& l: E* t) o! x; }1 X p, td, li { font-size : 12px ; } + K( V) J) l4 R% I3 v/ }( W: z
就是给li下面的子元素strong定义一个斜体不加粗的样式6 i2 `! S! ^5 P9 [4 E4 r. A
3 C0 L2 m3 F+ f6.id选择器
2 h+ A% e5 C3 K% n0 [3 C3 Q2 z. Y- ] a. {* e5 p
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
5 w- G+ y, E' I8 e; Z& r9 ~$ e% t' _: u7 O5 F
% {, r1 N+ e) a/ s$ B4 ^, y
然后在样式表里这样定义:3 Z) n# a+ D {
* _7 |$ j1 B5 Q
# C/ o q; [: n6 W5 F
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
" K7 B `# i8 P: Y其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
$ N& Z: x5 s9 f/ v9 I+ q) v5 f8 ^' q1 j; W5 l, b" D
id选择器也同样支持派生,例如:
% r1 o0 a# g$ X#menubar p { text-align : right; margin-top : 10px; } " Z# r4 O! Q+ E) T
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。3 u% x- E" b \& m
8 @& y' c' U2 t+ ], [ g
6.类别选择器- I1 u' j {, y1 M
* `) O' [ \! z9 u4 p- [. T
在CSS里用一个点开头表示类别选择器定义,例如:
" n* d+ `5 n- z* d2 Y1 H.14px {color : #f60 ;font-size:14px ;}
6 e: K# N( B' w9 `9 a7 J
( V3 Q; r# Q v- `4 ^( w3 X7 `在页面中,用class="类别名"的方法调用:2 G% i( O$ y) C0 |; U9 W+ L
<span class="14px">14px大小的字体</span> ! T) u" Q" w7 y5 ]
! P2 }" Y/ U4 H- f4 X这个方法比较简单灵活,可以随时根据页面需要新建和删除。8 E% O( P' V( O& `: F" S
# K1 [; f* b- y
7.定义链接的样式" o1 j% [' X' g% L
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
$ J4 I( P# K. Aa:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
$ ~$ c5 J6 N( ?5 }a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}& p( s. m+ X, K. V; |% W
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
* w } d0 H. v+ S8 La:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
) W: [0 `! k8 H7 Y, l; @7 j4 ^0 G. N( d8 q
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|