|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。
8 }3 H" x {+ R; D5 ? [; Q1 v7 u- y' N: v( k. H1 w3 l
1.基本语法规范
% L% x2 ]6 k5 |; D. I" @7 [分析一个典型CSS的语句:
+ m) g5 d6 t: W% p% G5 g# ap {COLOR:#FF0000;BACKGROUND:#FFFFFF}
) [' y) }# d0 y% P; v6 _. N* P6 t其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; 9 J) Y* p* Y! H) U% q
样式声明写在一对大括号"{}"中;
# H0 l' X8 C2 U8 _' y8 ?, zCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; & n9 f% X! {2 S& Y
"#FF0000"和"#FFFFFF"是属性的值(value)。" V9 V! H6 @! }$ F* I0 b
3 S* Y; [' R J4 t& v' i8 U2.颜色值" c4 V/ u2 b) r3 |
* j v% t1 j: I8 O* ^4 Y颜色值可以用RGB值写,例如:- d! E/ d0 K O* j
/ e- i+ s4 Z7 U8 N. a- `$ d
2 q, x4 d6 W* U8 q,也可以用十六进制写,就象上面例子
% z: k* K# r; m) h( a7 z8 p m) ?# J: A. K4 K2 O+ e a# Q, r* Q
/ j9 n* l2 i! X8 d; M8 ~
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
: L P' N" T. M6 ~5 {6 r. E' |4 D; I
3.定义字体% ?9 d6 j6 o! x* b. v: ^- [; |
web标准推荐如下字体定义方法
' Y, `! _' ?3 e! ?9 a3 p/ c
" u3 ~: t0 {, E% J! cbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
/ j& b/ m& T& [1 l2 ~+ G字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
3 {+ r4 I9 O, u* F4 f) L8 `7 aLucida Grande字体适合Mac OS X;
# A5 b& w& C4 ?& Q% WVerdana字体适合所有的Windows系统;
1 _ H/ A' Z3 @8 T1 jLucida适合UNIX用户
$ x6 H9 m" w# o' @" @+ l0 i; P"宋体"适合中文简体用户; + w8 x6 h2 F! O U
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
# n, F4 E9 k) ~- J
& V& y1 y9 N! G5 L, K: C- @4.群选择器6 _/ L, q ?1 u' F, _' L# K$ c
: W x6 W& s3 }
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:! R7 `7 g1 Y3 {2 r7 w# @! b2 |
6 A, N/ b& p( T
p, td, li { font-size : 12px ; } 2 F2 V6 W* Q1 g+ Z) i
就是给li下面的子元素strong定义一个斜体不加粗的样式. _$ o# K6 |2 C" D+ l; l3 @" `9 m
, f5 n. U h8 }( v4 \, ~
6.id选择器
y3 U$ }" L" B8 o+ }4 [" y$ W ~9 H; G; Z. K0 |5 u$ Q
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层' R; [/ d# U; O/ H5 O& m. z
% ]; a1 R7 Z3 v$ d
: [/ M. o0 i$ f- [! _然后在样式表里这样定义:
+ _2 Y8 X6 F" z O' K' f, V1 M: P' I
+ g r" n% k# F. c5 G
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
6 ?/ {* E2 D/ @6 H# }! s其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
/ k7 \4 ]4 K" x8 x- D# S6 ?# i' M, M9 i. W% C2 }: r0 {- i1 B* x
id选择器也同样支持派生,例如:: ?5 M [ h$ Q" @- [
#menubar p { text-align : right; margin-top : 10px; } & h, M* {% V. g1 W0 Z, Z6 L. m5 m
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。0 K) D8 y2 B$ ~2 N
$ {+ G! @# u8 g& @6.类别选择器- [# A. ]: M) L
1 D: f- }' C* a5 E/ r在CSS里用一个点开头表示类别选择器定义,例如:
$ l; f0 J7 M; U; W e# n.14px {color : #f60 ;font-size:14px ;} 5 n6 t" ]8 w4 w2 i+ N' X. j% R
0 @9 Y( f) v `# V5 N
在页面中,用class="类别名"的方法调用:
) Y2 _. z. a& c# W5 l<span class="14px">14px大小的字体</span>
% b% W4 A) Y' U, l) \9 U
: j. H4 m [& L- e# e这个方法比较简单灵活,可以随时根据页面需要新建和删除。$ {9 R }$ j+ `" E4 W! N
2 s8 Y4 U1 ?1 T& E6 {5 ]" M- S7.定义链接的样式- [% v0 b8 x P+ Z0 _& l, J
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
4 d/ R9 ?9 O8 v b; k. g: R' ^( Ua:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}% R% P1 {* ^& R' E
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
4 ?! _6 s5 v; q) d+ Ba:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
U4 i% b. R) J! Qa:active {font-weight : bold ;text-decoration : none ;color : #90 ;} 1 ~; M8 Q4 Q1 S% \! t% e9 P
: V8 B8 d6 C0 L/ k" O7 }+ F' ]以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|