|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。9 N& x, w0 M" E* ?! ]9 D% U' b
& Q$ c! [) x/ H2 w7 S8 t8 Z
1.基本语法规范3 @; T* k7 @- D! h+ W" p" y) ]
分析一个典型CSS的语句:
. }1 y7 B2 u( I% l+ B, Jp {COLOR:#FF0000;BACKGROUND:#FFFFFF} 9 K' b" z" d! `! C& U8 a
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; 2 L% d( k4 ?6 ^$ d( i
样式声明写在一对大括号"{}"中;
1 o; x* f& O. _1 j: P( _# c4 FCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; 0 M$ w. R G8 e( ^* P6 _4 H( F: V
"#FF0000"和"#FFFFFF"是属性的值(value)。
& k' T+ z) q) G( `. Z- q* `- ^, E
2.颜色值
1 _% x3 a1 m+ S) q9 r- S' ` S
( ^" w* M. r4 N) O: \+ j9 k颜色值可以用RGB值写,例如:
# ~: |8 f1 X6 ?5 [
! a( h0 P4 g* a* u$ A! t( z9 s; n$ m( R" K( B( X0 s
,也可以用十六进制写,就象上面例子
% m: h% U5 l, k
7 p. E' y( b& e+ C' T- P. i$ b' M, ^6 K$ R1 Z$ A
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。3 ^# \6 J g7 d* y" m1 _
2 j7 r4 a+ b+ P, K. r
3.定义字体2 a! m. h) A# `5 Q5 x: v- o3 |) ?
web标准推荐如下字体定义方法: I) a6 }( j% P6 T7 Q3 f ^
0 W* X2 s1 }+ {& v! ]
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; } 6 v& A, y% f, s+ {! O# n
字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; : P9 c. u2 Z4 j/ \; `5 Q
Lucida Grande字体适合Mac OS X; * E, B5 L3 z) f) Z8 z% W
Verdana字体适合所有的Windows系统; , x# ]/ c3 h# t1 Q. Y! g' }
Lucida适合UNIX用户
" M) u- L) N5 z( h! n"宋体"适合中文简体用户;
$ E$ r. ~1 S0 f如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
P k8 t. a1 R1 i2 @9 t B" N/ E2 }
, B5 [- u) S. O! n+ `* g R4.群选择器% W. w/ F0 E' v2 W/ \* I
0 C% U! |9 ^5 C! p6 ?
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:9 R8 b; a9 I$ u
; J. e% {3 x" B p, td, li { font-size : 12px ; } 3 }. k3 ?) B/ \1 n1 b
就是给li下面的子元素strong定义一个斜体不加粗的样式4 T; P7 v/ N5 a' r$ B: |5 g' q
5 S4 t) p$ J& Z9 J$ J6.id选择器
, {! ? Y, Z6 V/ H/ f7 k! n& ?* \% ~1 {& k6 L, H+ Z7 R
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层
2 d2 v6 H/ r" n6 C t
# ^4 j, e# }$ \5 c
& S0 A! g3 |3 q; I& p然后在样式表里这样定义:: j& R/ X: v2 B" U# a7 N4 ]# b. C
' v1 K9 B7 X; X2 ^6 U! d+ I
8 i- l& F- {& Q) M#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
9 W2 ]. K* y* G" l其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
' p! [% t+ {4 z$ g4 I% }( T) J+ w5 Z
id选择器也同样支持派生,例如:! u$ H8 W9 C6 Y7 ]0 g! I) o3 ^& n
#menubar p { text-align : right; margin-top : 10px; }
8 V: `0 k+ ~3 T7 j3 y% w* f这个方法主要用来定义层和那些比较复杂,有多个派生的元素。9 q/ }4 _( i3 F9 a$ v9 f5 f
; u0 e, m+ s7 M% s9 {2 W
6.类别选择器
0 d2 } j6 Y* w! z
8 H- @; w. i0 e+ T( c在CSS里用一个点开头表示类别选择器定义,例如:
. D' X0 M2 E: w L4 e2 v# V: K/ ~.14px {color : #f60 ;font-size:14px ;}
1 t* a' |- B0 {# ?5 g0 I/ T& k& h3 F6 [- G( i( ~5 t
在页面中,用class="类别名"的方法调用:& b8 P# X, k0 ^- E5 ~
<span class="14px">14px大小的字体</span>
- f" H. n6 m6 K( k" n( t$ s3 c7 v u+ }9 M! Q
这个方法比较简单灵活,可以随时根据页面需要新建和删除。% d: {6 g! A! G% J; \0 c- l
0 x: D0 c @+ o8 M2 t7.定义链接的样式
# t! K( ^, _$ Q. k8 |" |* jCSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
. p. E9 k6 j/ @$ {6 a8 K7 Ca:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}
! t0 d$ e! a# d# W3 d2 P. Fa:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
" u9 Q. e+ _ B; p6 J5 R! Da:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}9 x3 p/ @8 i) i2 }+ X! ]
a:active {font-weight : bold ;text-decoration : none ;color : #90 ;} * ?- K0 m& G2 U! j- H' D; g
U) V+ s, E5 l+ a5 Z: e0 w3 k2 ^
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|