一.使用css缩写9 S) [4 y4 S3 R t! i
使用缩写可以帮助减少你css文件的大小,更加容易阅读。css缩写的主要规则请参看《css基本语法》。( k8 U- ~4 K1 w/ r, Q
二.明确定义单位,除非值为0
# N- L# I7 l4 r7 h' h忘记定义尺寸的单位是css新手普遍的错误。在html中你可以只写;100,但是在css中,你必须给一个准确的单位,比如: width:100em。只有两个例外情况可以不定义单位:行高和0值。除此以外,其他值都必须紧跟单位,注意,不要在数值和单位之间加空格。
" n3 H% ?: F V0 F# E三.区分大小写
* o, k1 D6 o6 \9 |6 }9 g7 }0 K0 @当在xhtml中使用css,css里定义的元素名称是区分大小写的。为了避免这种错误,我建议所有的定义名称都采用小写。/ h! z4 U8 d- w; H; T
class和id的值在html和xhtml中也是区分大小写的,如果你一定要大小写混合写,请仔细确认你在css的定义和xhtml里的标签是一致的。; p$ G7 @2 V( ~% p' P0 x/ _
四.取消class和id前的元素限定
8 U l" j" k* x当你写给一个元素定义class或者id,你可以省略前面的元素限定,因为id在一个页面里是唯一的,鴆las s可以在页面中多次使用。你限定某个元素毫无意义。例如:- B+ Q' Z7 ^/ f6 _0 G3 M$ b0 e
div#content { /* declarations */ } " @8 x2 S- K* ]# e) i
fieldset.details { /* declarations */ }5 g. v5 {5 Z! Y* a [& p# }8 b" P
可以写成7 n" O: v3 y- j9 c9 z
#content { /* declarations */ } $ L# k: o' C& r, T' x" H: O
.details { /* declarations */ }3 |$ J3 E3 P9 v" q8 p
这样可以节省一些字节。, W' S, G8 Z0 W" P
五.默认值0 R4 b4 ~5 p& p( ?8 {
通常padding的默认值为0,background-color的默认值是transparent。但是在不同的浏览器默认值可能不同。如果怕有冲突,可以在样式表一开始就先定义所有元素的margin和padding值都为0,象这样:7 s& J4 r' s+ ]$ o. P% B
* {
' l* O7 R9 y* cmargin:0;
$ r$ B' ?! W- j' cpadding:0; : J* j" b g2 P u
}
, J1 [' ~# J9 ~: f0 J* y六.不需要重复定义可继承的值
# T/ k* L6 t) R8 X8 ycss中,子元素自动继承父元素的属性值,象颜色、字体等,已经在父元素中定义过的,在子元素中可以直接继承,不需要重复定义。但是要注意,浏览器可能用一些默认值覆盖你的定义。
|0 |/ m. L1 Z8 z七.最近优先原则
& ]1 R9 C# _ n! c如果对同一个元素的定义有多种,以最接近(最小一级)的定义为最优先,例如有这么一段代码$ M) P. `; B# x' }& b0 E
update: lorem ipsum dolor set
/ t) t) O/ v: @1 @: x: e& h# V" Q在css文件中,你已经定义了元素p,又定义了一个classupdate
f+ B$ v0 D* Yp {
2 n: F1 \1 n; K1 Q% umargin:1em 0;
. V! S1 U" w9 Nfont-size:1em;
+ o# }2 \5 {8 @/ Y5 @& R0 } L- n, [color:#333; 4 L1 p7 n0 b2 Z2 i Y3 X2 }! S: U: R
} ! z b% L5 v" | c
.update { 0 v& Y+ Q9 [/ D+ V
font-weight:bold; ' Z* }8 k5 U, g
color:#600; 8 W( y& G' @8 {+ z/ g0 H9 b% [
}% T/ T" T D+ a% u# U8 ]$ {
这两个定义中,class=update将被使用,因为class比p更近。你可以查阅w3c的《 calculating a selector’s specificity》 了解' ]0 X" i6 i4 H+ Q
更多网页制作信息请查看: 网页制作 |
|