|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。
* i- C3 P3 N. ` w% O9 |. }1 m! Q* A& Z/ e
2 H% s. B6 o, v' Q1.基本语法规范
M; {# m' @* C3 H! P, q7 ^: [2 m分析一个典型CSS的语句:: D1 M9 c! j* P8 b; ~
p {COLOR:#FF0000;BACKGROUND:#FFFFFF} ; \9 t* g% A- N/ b) X9 j3 l, w
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; : F5 y. {; P4 C$ j
样式声明写在一对大括号"{}"中;
6 u; @2 Y; ~8 d0 p7 LCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; ) o2 K( O4 ?4 t( ?2 ]
"#FF0000"和"#FFFFFF"是属性的值(value)。
/ u& Y0 b; d& k% ]( {$ G
+ d! E. M* u/ Z2 v1 z; J2.颜色值
" @* b. |8 i. T/ |& p$ O: G" d3 F* F$ D N' v, p
颜色值可以用RGB值写,例如:
/ X8 B" b2 R' Q6 X$ j% a
5 ~0 x6 ~8 h7 e/ D
2 x+ {6 ?( q- g,也可以用十六进制写,就象上面例子
) A3 |/ s3 O( \" M: B/ z( f* j, a
0 ?. D. H$ i5 G3 ?/ J+ c2 w
& @8 w, W) r7 {& n" U9 i6 w; }如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。' f" }5 n2 I' J- h4 P1 @" [- Z
5 }- x- T( w4 @3 P3.定义字体' ^/ V# B+ |6 n) i
web标准推荐如下字体定义方法
2 d$ A, L0 C( O& t+ C7 Z, f) D) z* t; A6 f5 @; h! C6 t
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
4 i/ C; u! L5 F: s字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; 4 E i3 v; i' U+ s! D9 `
Lucida Grande字体适合Mac OS X;
- b( ?: F) p: E' T+ q8 A. fVerdana字体适合所有的Windows系统;
8 O# Z0 B0 q/ n! yLucida适合UNIX用户 # w/ x p6 C0 b# z9 O* S4 Q
"宋体"适合中文简体用户; % h- P. J$ O- i+ |
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;+ I( o1 R; p X$ Q. l1 z
3 u y- S$ P/ {- k3 e4 j4.群选择器3 b/ O) L, ]: V j" j+ A6 V
4 x7 \! E5 `+ y% l/ H: D2 C6 e' [
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
" c) Y$ ^" W, T9 U1 R$ r0 y+ L9 Y" ?: P: c$ h
p, td, li { font-size : 12px ; } - K. p% ~9 ^( Q5 R' c
就是给li下面的子元素strong定义一个斜体不加粗的样式
8 I% Q# G- }3 z5 K* ?
+ B# A% q9 X/ T/ } ]1 ?6.id选择器
: D# c! m& ?1 h6 p
9 g' T5 Q4 ]3 @2 K3 c* c6 P+ N3 P; H用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层$ W) _+ l G6 u3 x- j% Y/ u. k4 z
4 h2 z9 v$ e/ |$ T
; S& h C( R3 h9 U) R% t! |# j然后在样式表里这样定义:
4 s- ~$ ]( q) e; E* T! L
9 Y6 |. g" R! K5 w3 y$ t; N; s
2 k# n/ {" [. R: f( C$ M#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;} 9 x7 n0 ^4 {& S, x& q0 i
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
: I6 x( D5 y, h+ ^ Q( o+ l
% e. W5 W. {2 Pid选择器也同样支持派生,例如:! Z: ^$ x' ^0 }0 E- n" J
#menubar p { text-align : right; margin-top : 10px; }
4 x; Y- N) N* d' c: V这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
, s+ b3 p" u" _3 ~0 ?+ R. Q6 [* f3 a D
6.类别选择器6 U) e1 l7 C: N0 F& L& O
6 G# F# _. A8 P" C在CSS里用一个点开头表示类别选择器定义,例如:
% e% ?$ `3 }7 o.14px {color : #f60 ;font-size:14px ;} - y$ ?, ?* m/ i' Z# F1 S n
3 r/ b4 B/ i T2 d在页面中,用class="类别名"的方法调用:
+ o, M6 X# r i- P<span class="14px">14px大小的字体</span> ( b ?* _* n7 d( i. j: e
; k) u6 o" o8 ]' u1 {1 s这个方法比较简单灵活,可以随时根据页面需要新建和删除。# O0 C7 h2 l3 R8 F2 z7 J/ r
9 k( T) E9 w; Q' P( c* w4 F9 K7 O
7.定义链接的样式5 {2 ~3 E" [( `$ n3 G( Z3 E
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
% v8 e' G* g7 R1 u Y2 Na:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}# ^: I2 @8 a$ A$ p! n5 E# C: C5 z- u
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}) r. v4 L. `8 O& x( M3 O
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
0 y2 I( a) ~, C% S2 ?0 ta:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
$ J/ V& @( J; Y- c1 |4 Q2 |4 l
" |" S* v( X; V, r# k) a3 h以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|