|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。" M( V' U) q0 C7 W" v. j
7 L7 D6 S1 Z$ T( [! ^5 z2 r4 d* T
1.基本语法规范
) K" {) P* `: ]% v8 D4 a# T分析一个典型CSS的语句:
8 u. h0 }* X9 m ^# y! [1 t6 np {COLOR:#FF0000;BACKGROUND:#FFFFFF} 4 Q _. s. I6 B V2 Y2 c, r
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式;
5 N0 P3 B* `$ D- ^4 z3 r5 X样式声明写在一对大括号"{}"中;
$ x( {' x. R! \+ x1 p% z& v. MCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
5 g- l @3 m0 n5 l6 y"#FF0000"和"#FFFFFF"是属性的值(value)。
+ z; G- V/ K3 u5 }. i4 E
% w7 v9 g. X; ^5 E4 t, s& |2 m2.颜色值# @% q7 N4 X" H" C4 K
9 Z- M6 V; K5 x) O& G: f2 |
颜色值可以用RGB值写,例如:
# J6 p$ P, p p
8 R7 C0 b }, r# d" I2 n9 T) ~) s# e
,也可以用十六进制写,就象上面例子" m, J* a2 J& f# u$ o+ A1 d
; O6 t0 n \8 B8 x: S! n* |6 P( C/ P' k$ w8 }8 ?
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。. i0 `$ X. X/ j5 `
( e! Z& N. ~- `+ Y- ?* E K2 V3.定义字体
- |1 j$ P3 i* ~+ f$ g: D! G; S5 i5 Aweb标准推荐如下字体定义方法
% @5 R# S$ j4 G2 _( W) `
3 m% u" Q5 ~' \$ y* A) V+ Fbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } ) j5 c, ^/ T% u7 ~" i0 Y
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
7 t" L4 P% f4 W% Z. Y. hLucida Grande字体适合Mac OS X;
% t5 [/ \ J/ W/ r* |Verdana字体适合所有的Windows系统; , ]( _/ n) k# m- q; {) d* m* g
Lucida适合UNIX用户 ; m! I, P7 m1 R( I0 Y6 {
"宋体"适合中文简体用户; ; J9 @% S8 g- C% V
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
- i( x$ b( ~6 \ i9 _& j# a# _* s' r: y8 g: P
4.群选择器
4 @: T% U0 O8 g; z1 E) V. x5 j2 d% {: h3 o
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
+ Y& w( L; p' c( x6 C4 }/ u& _, I/ d
p, td, li { font-size : 12px ; }
! M4 o3 ]1 ?2 v& j! w- z就是给li下面的子元素strong定义一个斜体不加粗的样式
( x7 W* ~, h/ T. K2 ^- S5 c4 {. U' t0 X( j
6.id选择器( J4 N4 w" x9 y7 @/ g
, m$ [" {) I2 ]. g; u4 [! x
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层) a% H* o" q5 Y8 `
! o+ L5 o( L- l1 J- `- D# e6 Q
5 }$ d; \2 Z( [9 ~
然后在样式表里这样定义:
& e ^. u( b7 S" N8 e- V: X* Q' M2 x# P) i; ^
7 u. A) ~% m4 b7 U4 k#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;} " b9 K* v( `+ i8 t; A/ `
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
7 p& X6 F" N) x7 }0 k7 [% A1 z
5 X3 C6 l$ k: Yid选择器也同样支持派生,例如:2 H4 f- J" j2 \( j
#menubar p { text-align : right; margin-top : 10px; }
! V- ~( g3 `+ h; L9 ]这个方法主要用来定义层和那些比较复杂,有多个派生的元素。5 O. o. {" J2 R2 |" T
3 o$ z& i- O0 S: b# W. B9 B
6.类别选择器$ D% h3 P; u) U2 y" @, R
, D( z0 H$ u3 ]
在CSS里用一个点开头表示类别选择器定义,例如:
, V1 v' F! t6 B* v& b( c8 C.14px {color : #f60 ;font-size:14px ;} & O' V7 {2 F2 f1 y( C
3 g- C, _# u) @+ d) Q! u在页面中,用class="类别名"的方法调用:
8 J9 R; f/ c$ _* O, z+ B" j& i1 J<span class="14px">14px大小的字体</span> 6 u. a Z* c& V/ U3 H$ p+ G
2 C4 D4 H2 R( e. w" Q: v
这个方法比较简单灵活,可以随时根据页面需要新建和删除。 {" l' Q: x- X) J* p
; o0 |* }* J' O; K9 t0 y' F7.定义链接的样式
% x& @4 G* C* G# ~% FCSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:( z4 ^' S h+ l4 g$ e |7 w9 [* a
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}- g* g3 H F0 p, P0 N
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}* y+ ~0 n+ B* o+ F2 g5 }
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
" U: c! w5 W: n' {# N' xa:active {font-weight : bold ;text-decoration : none ;color : #90 ;} ) S8 O8 z8 Y5 [/ i5 e9 F2 C o
! r3 _$ Y) \! i3 @! [; Z
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|