|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。/ E$ I+ d( z/ o' [5 [# C
6 R( A( E, V9 Y% N( d! A" }6 u$ p/ b
1.基本语法规范4 X, r. i3 m C$ g K( C5 h
分析一个典型CSS的语句:+ m2 P. O! Y* a- W! a/ t; |0 k
p {COLOR:#FF0000;BACKGROUND:#FFFFFF} % q' c- x8 C! f5 @9 P, x0 J
其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; 8 m* a- q8 O; \# v8 V c6 I5 s
样式声明写在一对大括号"{}"中;
; O% Y* F' K4 w: \+ tCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔; ; Y& a* N2 S6 \* ]7 y
"#FF0000"和"#FFFFFF"是属性的值(value)。0 M8 }: B- m& \& [8 r7 I# ?9 F4 y
- r/ P( H5 j/ ^- M1 b2.颜色值$ w( v7 q% c0 R) K6 x
: D) z0 a- s$ U4 b" S3 n颜色值可以用RGB值写,例如:
, {: I* ?" r3 y- J+ N2 Z4 {& v. O2 c# k1 e+ [! y
+ r' \6 f. w, B+ B$ b+ w! j
,也可以用十六进制写,就象上面例子
. T- G3 K7 {4 B6 k9 ^8 N
_6 v& c7 D. G
# e: E- e, u, u3 ?8 K% d3 F如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。) i$ c1 n9 a* _' k, p
$ w5 U7 I2 m1 m; j, Q, W
3.定义字体5 J4 R! ^# @7 B# a4 n0 `+ t& F D
web标准推荐如下字体定义方法5 l9 X) h8 @+ W/ k7 l# ]) ]! L
% K$ W* Y' g+ i7 k6 Kbody { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
6 Q2 o o7 M& ?5 b- L/ ]2 I字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; 5 }; a$ j; A+ ^
Lucida Grande字体适合Mac OS X;
7 C+ k# D# r w s5 YVerdana字体适合所有的Windows系统;
" g* B% ^+ X) J8 kLucida适合UNIX用户 1 S, l& @, u3 \# ^( C
"宋体"适合中文简体用户; - P: _3 X' R1 K/ l
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
; X( C# V0 s8 J3 \0 G3 M
2 S0 x# h1 H! l! t& k0 o4.群选择器5 p# D& u6 x4 g5 }& t7 q) V
$ y# Z3 i! {7 l当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:9 C8 E1 |: D0 _% e. p
7 O* J( z+ K; J0 M7 ?& [ p, td, li { font-size : 12px ; }
4 R; H1 w4 E4 S+ n; R+ A/ M就是给li下面的子元素strong定义一个斜体不加粗的样式
; z3 F! I& v4 a5 J% }
2 X: F$ G$ J7 _" h5 g8 J! f, t% B6.id选择器
1 l u' X" V( Z$ o- z
2 Z- S. k6 P+ }( l9 j( H2 _8 }' ~用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层6 ~% R5 _' G$ _% h% o
' N3 Y. m. o) \) |* m* I! p& X: O! G! _' Y3 E- n6 ^1 P& Q" G& P, H
然后在样式表里这样定义:
1 p5 F0 T" ]8 u) }$ C% y9 \% i
, b* i# b; X' E6 _4 e0 e; O* s; [' z/ ~- Z5 a2 m
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;} 1 F5 c3 {: V: c) C
其中"menubar"是你自己定义的id名称。注意在前面加"#"号。 k6 t1 @' L( h; X
1 E& M9 Q/ u3 h( ]
id选择器也同样支持派生,例如:
7 V$ @. g+ z. o& t. S#menubar p { text-align : right; margin-top : 10px; } ; L l9 ^! r, f7 w$ C- G z3 N
这个方法主要用来定义层和那些比较复杂,有多个派生的元素。" }; ?' I4 G5 T
3 U6 U" M8 }+ X2 I* h
6.类别选择器
5 O# o3 B9 X8 L) \; U v: N% ?$ {. q4 ]2 H5 ^4 T3 Y: E% ` D
在CSS里用一个点开头表示类别选择器定义,例如:: p1 |, B$ T- T
.14px {color : #f60 ;font-size:14px ;} , H8 w* ?- d0 G; P& |& m8 W; m
. y# n* r5 v m' j( w4 C$ J
在页面中,用class="类别名"的方法调用:
3 ^9 R( U8 W* K h. I<span class="14px">14px大小的字体</span>
: r0 D9 J" K% H5 K% x: {4 g
5 \: p8 p) ?9 m; _这个方法比较简单灵活,可以随时根据页面需要新建和删除。
) o) q6 g! }" L( s
0 |$ l5 r% t: u! b" S+ T+ `* @7.定义链接的样式4 g* I5 p* m% k4 V5 d' U: G- G4 F
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:9 \8 s* L/ z; ~
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}, u5 [" e1 \! ~) g. z* E0 A# T! f
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}2 G& {) v {! p4 P1 Z2 R
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}/ k3 R) a" \& U& J5 D
a:active {font-weight : bold ;text-decoration : none ;color : #90 ;}
5 F. F' x' T" U' ]! W
2 l: a! Q0 W4 o% }以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|