|
|
CSS是Cascading Style Sheets(层叠样式表)的缩写。是一种对web文档添加样式的简单机制,属于表现层的布局语言。0 t5 S8 W# b' |$ H
. R5 ?2 s8 w% V" W4 u9 y1.基本语法规范- [/ `: B7 b# I6 s: @4 H$ m t- b
分析一个典型CSS的语句:4 K3 n+ b/ f& A5 E6 b A
p {COLOR:#FF0000;BACKGROUND:#FFFFFF}
1 ^, e0 T1 K+ C, @" W其中"p"我们称为"选择器"(selectors),指明我们要给"p"定义样式; 3 w: j; ?( m: j
样式声明写在一对大括号"{}"中;
6 O( ^5 {/ ^4 _9 Y4 E$ e9 hCOLOR和BACKGROUND称为"属性"(property),不同属性之间用分号";"分隔;
. U- C; Q' s- f/ G l"#FF0000"和"#FFFFFF"是属性的值(value)。
F+ f. J0 @7 R5 s8 d* ?0 e
; S5 v6 C. _ y2 I' b* ~4 m- g2.颜色值
6 c2 u! M! v7 r9 ?" E! n1 p. p8 }# L( t0 ^) ^3 E" W
颜色值可以用RGB值写,例如:
0 C# L( z3 V$ g( L" J5 \# t7 C- X1 i' q
- M5 {; G4 h* Z7 K* Q3 Q7 P
,也可以用十六进制写,就象上面例子- l9 |! S& A$ M' U* C! Y& w: [! W, Z
6 t% Q3 _: [& c3 Y
6 l$ [, v. Q% d5 s7 w4 E( v如果十六进制值是成对重复的可以简写,效果一样。例如:#FF0000可以写成#F00。但如果不重复就不可以简写,例如#FC1A1B必须写满六位。
3 a' s6 o; ]0 I4 r/ O& O7 G7 k
3.定义字体( o' G$ ?0 U N3 Z
web标准推荐如下字体定义方法
5 [- }( i) b9 @5 S7 }8 X7 p9 W0 x7 A' K" s) K/ R; Y0 g. V3 A! h
body { font-family : "Lucida Grande", Verdana, Lucida, Arial, Helvetica, 宋体,sans-serif; }
$ h; `* T M* h+ q4 ]) |字体按照所列出的顺序选用。如果用户的计算机含有Lucida Grande字体,文档将被指定为Lucida Grande。没有的话,就被指定为Verdana字体,如果也没有Verdana,就指定为Lucida字体,依此类推,;
6 }3 R3 C) I" Q0 s. H: X1 FLucida Grande字体适合Mac OS X;
2 M$ W9 k% l( H9 V, F! ZVerdana字体适合所有的Windows系统;
0 }: ^2 n2 t$ M3 BLucida适合UNIX用户
3 f; J$ d# I- N4 y"宋体"适合中文简体用户; 6 A/ o+ P* @8 y; \5 \- E' D7 D" n/ U
如果所列出的字体都不能用,则默认的sans-serif字体能保证调用;
; f/ x- p! q/ F; p6 `9 N# l! C3 e) n$ \
4.群选择器
# N5 M- I( e. `+ x1 i4 i- l( |+ p1 S7 v8 Q
当几个元素样式属性一样时,可以共同调用一个声明,元素之间用逗号分隔,:
! U- ~: [8 J9 T( T# C, R5 D0 D% ?$ A( M) S) A6 M8 T/ W5 g% U
p, td, li { font-size : 12px ; } ( Q. Z( V' s0 u# a2 n" r: }
就是给li下面的子元素strong定义一个斜体不加粗的样式1 @; d( Z; |, B' Y
5 w, R- E! k3 j. d2 D0 Z
6.id选择器$ j9 N# ^ b2 V% e7 [3 b' z7 a; l
7 B$ o6 r' a8 w5 I& i用CSS布局主要用层"div"来实现,而div的样式通过"id选择器"来定义。例如我们首先定义一个层6 c, A; b; m# R& C
/ h# U; n* S- {( g9 u. A# A; @" z
+ ^( \; g' d# }% M# w# r1 L然后在样式表里这样定义:( Z0 H0 _( ^# L# S- a
" Q# u7 q7 Z: G. `
- Z0 r( k/ ~; n& N% [3 Y* b#menubar {MARGIN: 0px;BACKGROUND: #FEFEFE;COLOR: #666;}
- F x: X' r1 w5 J其中"menubar"是你自己定义的id名称。注意在前面加"#"号。
& W1 `' m& G; b; ?
) k; U* S. P7 C$ s2 `' }id选择器也同样支持派生,例如:" D4 Z* G5 s5 b! M$ ~/ d; x9 d: h
#menubar p { text-align : right; margin-top : 10px; }
: ?' ]2 t5 }6 o. q9 @0 \4 M: F2 K这个方法主要用来定义层和那些比较复杂,有多个派生的元素。
6 S3 l. d( \1 x- o; q5 q( L A& m9 {+ ~1 @7 j
6.类别选择器% v. X' m6 Z7 ^+ P$ K
: W; q' R8 C5 V- J
在CSS里用一个点开头表示类别选择器定义,例如:% D0 u. V. u4 _. |. g& B' F6 ^
.14px {color : #f60 ;font-size:14px ;} # ?5 ?! e8 A! j. X* b
0 r& t6 Y3 h* m+ L1 @
在页面中,用class="类别名"的方法调用:: c; t" b! L' C- r
<span class="14px">14px大小的字体</span>
2 x3 d, [, Z$ v' v
* k* T$ e8 _; o' D这个方法比较简单灵活,可以随时根据页面需要新建和删除。, q J1 U1 X( e9 p5 H
7 z8 ^; s4 }4 v+ z; T7.定义链接的样式7 e& X6 L6 F# b8 R% [
CSS中用四个伪类来定义链接的样式,分别是:a:link、a:visited、a:hover和a : active,例如:
7 d' v* m) q+ j7 t5 ~9 k5 la:link{font-weight : bold ;text-decoration : none ;color : #c00 ;}0 Z! Q- ~! I7 n7 {6 x" Y
a:visited {font-weight : bold ;text-decoration : none ;color : #c30 ;}$ l) a( k( v/ h/ C) `
a:hover {font-weight : bold ;text-decoration : underline ;color : #f60 ;}4 _5 Y$ `4 P3 Q
a:active {font-weight : bold ;text-decoration : none ;color : #90 ;} " {- D2 x7 \/ C
4 c" l" d# u2 b- V' B. Q/ y
以上语句分别定义了"链接、已访问过的链接、鼠标停在上方时、点下鼠标时"的样式。注意,必须按以上顺序写,否则显示可能和你预想的不一样。记住它们的顺序是“LVHA”。 |
|