|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。5 P; _9 v& B/ i( i
* B/ v) \: {" n. J! P; d1.基本语法规范
! J' m9 `9 k, ^2 |& y( L) H; c2 Y& W6 [9 k分析一个典型CSS的语句:) L1 k* y5 O5 o9 Z4 m
p {COLOR:#FF0000;BACKGROUND:#FFFFFF} " R7 z( ]3 u- f2 C* F! w/ c- S# P
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
: J+ `5 q6 T: Y样式声明写在一对大括号"{}"中; ) ^9 q$ [0 ~2 Q F( f h! I" ~9 \9 U) R
COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; : Y; M0 G* x$ E6 n- }' {( e% w! V. u
"#FF0000"和"#FFFFFF"是属性的值(value)。2 u1 y6 g" T* J% J4 a
, ?/ r/ g! D6 ?! W) y
2.颜色值5 }! B3 m7 R( j' {
/ F; ?7 d6 `2 V( t4 G
颜色值可以用RGB值写,例如:
7 U( r' J8 V0 k( l; S. e# }
# w3 Y: ]2 S. |+ \" r* s' }. G" w8 `% ~. z) b
,也可以用十六进制写,就象上面例子. k% Z) T5 j* l9 `% X" x2 I
% L0 H6 i: M4 N) R- Y/ K7 s: Q7 b/ ?' n. Q4 }3 H( z
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
1 ^" u- T# V! X) r6 }* g! O5 V+ Q9 W5 r
3.定义字体* G q5 K" n- C; l; C @8 L
web标准推荐如下字体定义方法
; B6 a& D" f% G! _/ P6 v7 Q0 k$ P: m" }2 _% d- V$ k
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } . F- H6 `+ S4 |
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; 0 |5 e5 j7 B% ^
Lucida Grande字体适合Mac OS X; / S7 H9 s }: x) c! k. z
Verdana字体适合所有的Windows系统;
* N, [) q% Z4 x" o! S2 M# d3 d cLucida适合UNIX用户
4 n1 t+ E7 R' I1 D; ~) r: a8 M"宋体"适合中文简体用户; * N1 n2 M& E+ L) D0 G5 l
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
' ] ]+ J* [7 R# v/ ]" M) I/ J2 |5 Q6 c4 W9 K8 O
4.群选择器
9 v d3 t* U- X# c& g; V& W" I4 l
: ]& O( a$ D5 W4 }0 E当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
/ i( q$ t: t; I
0 |" c0 v% L6 P6 E7 O9 h p, td, li { font-size : 12px ; } 2 z) C9 V3 o9 C B7 Q) ?
就是给li下面的子元素strong定义一个斜体不加粗的样式+ Z& { |& g) ~' n
) x+ J( q- x5 r9 J/ ^
6.id选择器
* G4 W0 n) R" T% K( f$ O; |) a7 E
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
' ~1 p0 n0 c3 c
9 k$ `* m4 O1 n, @0 X7 y# M+ i+ o- i; p5 {, p) f) q. Y
然后在样式表里这样定义:' Z+ Q% }1 R) y ^
* `/ K$ x/ P% k6 g" o; E, C
4 f! O5 V( u7 Q#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
4 [0 ~1 N; H) t其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
0 L- g6 I+ ^) e9 H
' |0 I# k, j) N m/ @/ O; }id选择器也同样支持派生,例如:
P' m/ a6 K- v* L) K* g#menubar p { text-align : right; margin-top : 10px; } ; K0 V1 T& W# v i" C, l2 g. {
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
c# G+ f% d( a5 Z( Z% V1 e N/ ]# I H0 t$ S0 I& w3 [$ G
6.类别选择器
7 ]" o$ |) h2 h
9 K! D5 O; b' J/ x q' u# Q1 ?' L在CSS里用一个点开头表示类别选择器定义,例如:
+ V: V$ K% p# `. e8 c0 |* c( p1 Z.14px {color : #f60 ;font-size:14px ;}
2 S+ k* b2 t: J( N+ f2 w
# y# m4 Y' x1 n- ~: l在页面中,用class="类别名"的方法调用:
' b# y5 y6 m4 c* B( D* i3 q<span class="14px">14px大小的字体</span>
9 ?; t7 I9 o1 f# u9 h/ {3 C
+ D/ H# x2 T. l这个方法比较简单灵活,可以随时根据页面需要新建和删除。
4 Q5 C) r3 f k# \ ]1 t' E; b
, | V+ d8 { U7.定义链接的样式9 s: B+ _# s/ e5 m% X8 g
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
* |* y5 m9 Z2 ~5 H! r$ ta:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}: P2 Z1 U- k' Y# ]
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
7 |( `- b4 f* r. ~% k) c) Aa:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
# Q4 ?' W: T. G! [. b+ `a:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
' S/ l; I0 Q( b5 L; M5 P: [5 ^" c% p3 p7 D! L
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|