|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。1 {$ @7 M$ [' k5 w6 m- _- X6 q$ Y
6 U# U+ X2 s. ]( F
1.基本语法规范( P; ^7 w+ z8 _1 ~ A
分析一个典型CSS的语句:
, M4 f2 J+ v. p4 Mp {COLOR:#FF0000;BACKGROUND:#FFFFFF}
9 G8 G8 d( w3 i; H6 \7 [其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; $ } H0 K/ i* {4 p/ V$ g/ D2 t
样式声明写在一对大括号"{}"中; # W/ q! [; l0 w
COLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
$ X; E3 @& [/ `"#FF0000"和"#FFFFFF"是属性的值(value)。
* z! O" `, b0 ^& g* m, z: X5 i. f
# `, ?7 `0 P$ y6 l2 q5 b" t Q0 O9 m: v2.颜色值
. B' U7 b$ `, }# v, ~2 j
0 P) R. F9 Z% }7 T ?$ B! ?颜色值可以用RGB值写,例如:
. W% N) i# Z8 U0 N8 [
6 f, @( C6 J! j# {8 X P' B2 G/ E
2 F3 l, A; t# r5 r7 H,也可以用十六进制写,就象上面例子
$ U9 R- p, `$ P& }% ~" v) L% Y# [
+ \% z1 b0 u) x! V' F. P+ f3 x5 a4 y' A }( @* U
如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
7 S8 f( ^9 d/ f7 n. \ k( ^+ Q( b) }5 v' F+ C( ]
3.定义字体# f" M: s# V1 {4 ^6 F
web标准推荐如下字体定义方法7 P$ U4 Y& y i# y0 s6 i! {# H
, Y% Y3 b5 @" E) l' N V. K% R2 @body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
]5 K$ f/ x3 w4 @5 @字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,; 5 H" z% h, U) L; z* V) J) @
Lucida Grande字体适合Mac OS X;
0 M* `) T9 D0 Y0 t" k$ s& y- Z, HVerdana字体适合所有的Windows系统;
5 S. \/ F; b. X7 r; X) O k% S/ q) iLucida适合UNIX用户
* C8 R9 y! s% S/ F/ ["宋体"适合中文简体用户; 3 q/ M4 c9 m- e) P7 t. x
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
; B S5 V. H! F
: v+ Q' \$ p' b4 H- |4.群选择器. y/ c+ I: S: {0 D
$ a( s" \- Q/ Z- L5 {# s4 b; [7 P+ I2 W当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:& c: P& ]7 ]" g1 |3 K
# z. n& z0 s P. y9 p; [1 ? p, td, li { font-size : 12px ; }
9 ]8 f# H7 O- \ k2 p就是给li下面的子元素strong定义一个斜体不加粗的样式/ q5 p* U {+ A7 k$ R
$ Q& E2 q1 v- ]- k4 n6.id选择器! O0 }# K+ m; h9 ?5 ]" R
! h% S3 U0 v4 z$ R
用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层+ g5 w4 O$ n0 o( a- Y- I" N. v+ u
) a1 c- F; l0 S8 x# W9 \
2 Z/ Y `9 w' O$ T J然后在样式表里这样定义:% o, o- Z9 l% q/ R( Q( G# k% n7 d
6 F1 @2 J3 a/ u1 D
) x1 P7 e1 _' C3 t: f- g2 Q
#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
. {, ~" p1 @6 L* l" g, N& U3 [3 q3 l其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
5 A0 u6 n& d" K8 Q
" C' g6 @# Q# v$ S6 O# o9 N {$ Jid选择器也同样支持派生,例如:5 g! c& |% @- j9 R5 z
#menubar p { text-align : right; margin-top : 10px; }
2 y7 E- e8 t) `: ]% A# i8 H这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
" j: N& S6 {$ u% R/ A
$ ] u+ |3 Y( r: C% |. w, o% P6.类别选择器 n3 J+ B! U$ B9 @8 p9 V, W+ e
6 l, y6 C m( X8 O/ c- O4 w4 O
在CSS里用一个点开头表示类别选择器定义,例如:1 V. ]6 o# _ ^ z
.14px {color : #f60 ;font-size:14px ;} 7 b* H0 \1 D) r! u1 `+ h. ?: ]
; t6 v7 q6 u5 O7 A
在页面中,用class="类别名"的方法调用:- [' _+ W# C/ \! ^$ a/ n/ W5 e2 K
<span class="14px">14px大小的字体</span> B4 @. n: Z$ q5 j: n: ]
3 ?6 O3 |$ A" o: E这个方法比较简单灵活,可以随时根据页面需要新建和删除。
5 o4 U( k0 ]2 q: x7 v$ c' _! V$ c! X3 j) t
7.定义链接的样式$ q, }& N& f# a% I: [1 D0 m
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:0 B+ R; {' s7 P, r3 ?
a:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}2 Q% Y) \; i8 ]6 ]
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}
7 w, K( c1 _8 D) O- E3 Oa:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}
/ ~- B+ ]( b5 p4 Da:active {font-weight : bold ;text-decoration : none ;color : #90 ;} * i' h* l& e0 Q8 n7 Q+ E7 h
7 S, N7 F3 K% |3 b" U以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|