|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。: h0 r; k6 }: r, B$ s* G- T/ |' X
4 L8 q# o z0 I& s. Q0 L
1.基本语法规范1 j0 U u- A/ l- U8 \) |
分析一个典型CSS的语句:
: i# F5 p- F3 c9 i% [p {COLOR:#FF0000;BACKGROUND:#FFFFFF} 0 s' y2 |8 y. V8 r& \$ y
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; + T( Z- c8 _3 l' \: Y2 L- z/ i
样式声明写在一对大括号"{}"中;
! R/ {9 F9 w. h0 ~/ ~COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
# X9 Y8 T- p# A- ~* T"#FF0000"和"#FFFFFF"是属性的值(value)。/ U7 [5 B! i1 R% F
* K* |% S. x, H- j% ]* H
2.颜色值
# H+ I* P: @8 I7 }2 Q6 x( R" J/ E3 d4 y/ x m
颜色值可以用RGB值写,例如:# G- g9 k! G! D, x, ^" U& R3 C
: J; ^: B9 C4 |: l. i! w) \
* ~& o5 E! |/ r,也可以用十六进制写,就象上面例子0 `( x/ m6 p; m N
, l& L) ?1 c) d0 ^! G# \
4 X% ?5 a0 R& R) j0 ]如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。6 X5 }9 `/ E7 ?- t# Q
7 R# a: F* u& U) D f( C; @" N6 c
3.定义字体& M) @" D. T& U
web标准推荐如下字体定义方法
% R! l" w7 X1 y
. t; e' D8 T- e$ I! N1 y8 f$ Bbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
( O1 y" g* l @. q. q+ O字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; 1 _! q$ B0 y7 J3 v D
Lucida Grande字体适合Mac OS X;
c# P5 j4 J: Z1 Q2 kVerdana字体适合所有的Windows系统;
# y% T W2 r5 A' n7 XLucida适合UNIX用户
$ ?* l& {" O! u' h1 Y"宋体"适合中文简体用户; 0 `: s) I& Y4 e9 o( Y
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;# e& l9 @: \) B' K8 Z7 Q1 _) h1 p
5 e; n; @0 u( Z. I
4.群选择器
( W+ A) f; i5 g, }4 u' C
0 K* f0 r5 |3 `4 {5 \; _ y当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
- a; V, P$ a$ h* W+ {
# F: ^' t9 B1 [8 C! ^ p, td, li { font-size : 12px ; }
" @& [2 q% V, C- a- v, H就是给li下面的子元素strong定义一个斜体不加粗的样式% C- r+ O) g$ Y5 o/ M
0 w- W& q8 T; I8 @; X
6.id选择器. G/ ]) l5 t1 J8 c5 ^: C$ {6 a
1 T; Y1 l0 V2 w5 L0 G4 y
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
' Q- z7 h6 ~5 `6 x* [9 H0 q! W
: {. i( O$ U) e5 b" q
8 i+ m3 B& \0 D1 X- [4 J% M# a c然后在样式表里这样定义:
: R/ w' |2 M/ |# M* B( C' m
5 i E; Y- H2 t5 {2 g' n! x/ r) V8 s
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
% T( z8 e5 O% ~' h6 ^其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
( \% b |+ b4 M( @7 c1 S5 ^# ?# n C0 r8 a1 o- z Q
id选择器也同样支持派生,例如:/ M$ ]7 Z! t2 d* ^" S0 ?
#menubar p { text-align : right; margin-top : 10px; }
$ p& y' \. v+ a$ e$ `) N这个方法主要用来定义层和那些比较复杂,有多个派生的元素。( S, E( x( |+ V* b
% ^& a. x! V' D( B1 {
6.类别选择器
! O' ]9 P* ~; a9 @ B0 s6 C* @; t6 z
在CSS里用一个点开头表示类别选择器定义,例如:/ j! J' K/ g: X8 a! a# O1 |" \# q
.14px {color : #f60 ;font-size:14px ;} 1 l+ ]8 |, R: c l' X# ?6 q/ [
! x5 @5 F3 O1 Z4 V4 Q
在页面中,用class="类别名"的方法调用:
& F ]4 Z3 ~7 h<span class="14px">14px大小的字体</span> $ B8 U# o& Q, e3 d c5 x
# o. E% q# z( [0 p& i9 V% |/ P
这个方法比较简单灵活,可以随时根据页面需要新建和删除。" L+ b5 h- g( b: S
( k! \8 X- ~' z- J
7.定义链接的样式' R! x% |. u& g3 x" d5 V% w) x3 I
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
, f% N7 O O" e7 O* H4 sa:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}6 L" l6 b1 E$ E; H6 w2 w0 [
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
+ ? f9 [; k* ]a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}1 H0 E5 X b# j5 l" c. t! U E
a:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
/ [9 K$ N! K4 V6 r1 o& F$ l3 H% M; T3 H
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|