一.使用css縮寫
使用縮寫可以幫助減少你css文件的大小,更加容易閱讀。css縮寫的主要規(guī)則請參看《css基本語法》。
二.明確定義單位,除非值為0
忘記定義尺寸的單位是css新手普遍的錯誤。在html中你可以只寫;100,但是在css中,你必須給一個準確的單位,比如: width:100em。只有兩個例外情況可以不定義單位:行高和0值。除此以外,其他值都必須緊跟單位,注意,不要在數(shù)值和單位之間加空格。
三.區(qū)分大小寫
當(dāng)在xhtml中使用css,css里定義的元素名稱是區(qū)分大小寫的。為了避免這種錯誤,我建議所有的定義名稱都采用小寫。
class和id的值在html和xhtml中也是區(qū)分大小寫的,如果你一定要大小寫混合寫,請仔細確認你在css的定義和xhtml里的標(biāo)簽是一致的。
四.取消class和id前的元素限定
當(dāng)你寫給一個元素定義class或者id,你可以省略前面的元素限定,因為id在一個頁面里是唯一的,鴆las s可以在頁面中多次使用。你限定某個元素毫無意義。例如:
div#content { /* declarations */ }
fieldset.details { /* declarations */ }
可以寫成
#content { /* declarations */ }
.details { /* declarations */ }
這樣可以節(jié)省一些字節(jié)。
五.默認值
通常padding的默認值為0,background-color的默認值是transparent。但是在不同的瀏覽器默認值可能不同。如果怕有沖突,可以在樣式表一開始就先定義所有元素的margin和padding值都為0,象這樣:
* {
margin:0;
padding:0;
}
六.不需要重復(fù)定義可繼承的值
css中,子元素自動繼承父元素的屬性值,象顏色、字體等,已經(jīng)在父元素中定義過的,在子元素中可以直接繼承,不需要重復(fù)定義。但是要注意,瀏覽器可能用一些默認值覆蓋你的定義。
七.最近優(yōu)先原則
如果對同一個元素的定義有多種,以最接近(最小一級)的定義為最優(yōu)先,例如有這么一段代碼
update: lorem ipsum dolor set
在css文件中,你已經(jīng)定義了元素p,又定義了一個classupdate
p {
margin:1em 0;
font-size:1em;
color:#333;
}
.update {
font-weight:bold;
color:#600;
}
這兩個定義中,class=update將被使用,因為class比p更近。你可以查閱w3c的《 calculating a selector’s specificity》 了解