在講CSS優(yōu)先級之前,我們得要了解什么是CSS,CSS是用來做什么的。
首先,我們對CSS作一個簡單的說明:CSS是層疊樣式表(Cascading Style Sheets)的簡稱。它的規(guī)范代表了互聯(lián)網(wǎng)歷史上一個獨特的發(fā)展階段。現(xiàn)在對于從事網(wǎng)頁制作的朋友來說,應(yīng)該很少沒有聽說過CSS了,因為在制作網(wǎng)頁過 程中我們經(jīng)常需要用到。
其次:我們能通過CSS為文檔設(shè)置豐富且易于修改的外觀,以減輕網(wǎng)頁制作者的工作負(fù)擔(dān),從而減輕制作及后期維護(hù)的代價。
其實現(xiàn)在還來講CSS是什么,CSS有什么作用完全是多余的,相信從事網(wǎng)頁制作的朋友都已經(jīng)或多或少的接觸過了。
言歸正傳,我們開始進(jìn)入今天的話題:
一、什么是CSS優(yōu)先級?
所謂CSS優(yōu)先級,即是指CSS樣式在瀏覽器中被解析的先后順序。
二、CSS優(yōu)先級規(guī)則
既然樣式有優(yōu)先級,那么就會有一個規(guī)則來約定這個優(yōu)先級,而這個“規(guī)則”就是本次所需要講的重點。
樣式表中的特殊性描述了不同規(guī)則的相對權(quán)重,它的基本規(guī)則是:
- 統(tǒng)計選擇符中的ID屬性個數(shù)。
- 統(tǒng)計選擇符中的CLASS屬性個數(shù)。
- 統(tǒng)計選擇符中的HTML標(biāo)記名個數(shù)。
最后,按正確的順序?qū)懗鋈齻數(shù)字,不要加空格或逗號,得到一個三位數(shù)(css2.1是用4位數(shù)表示)。( 注意,你需要把數(shù)字轉(zhuǎn)換成一個以三個數(shù)字結(jié)尾的更大的數(shù))。相應(yīng)于選擇符的最終數(shù)字列表可以很容易確定較高數(shù)字特性凌駕于較低數(shù)字的。
例如:
- 每個ID選擇符(#someid),加 0,1,0,0。
- 每個class選擇符(.someclass)、每個屬性選擇符(形如[attr=value]等)、每個偽類(形如:hover等)加0,0,1,0。
- 每個元素或偽元素(:firstchild)等,加0,0,0,1。
- 其它選擇符包括全局選擇符*,加0,0,0,0。相當(dāng)于沒加,不過這也是一種specificity,后面會解釋。
三、特性分類的選擇符列表
以下是一個按特性分類的選擇符的列表:
選擇符 |
特性值 |
h1 {color:blue;} |
1 |
p em {color:purple;} |
2 |
.apple {color:red;} |
10 |
p.bright {color:yellow;} |
11 |
p.bright em.dark {color:brown;} |
22 |
#id316 {color:yellow} |
100 |
單從上面這個表來看,貌似不大好理解,下面再給出一張表:
選擇符 |
特性值 |
h1 {color:blue;} |
1 |
p em {color:purple;} |
1+1=2 |
.apple {color:red;} |
10 |
p.bright {color:yellow;} |
1+10=11 |
p.bright em.dark {color:brown;} |
1+10+1+10=22 |
#id316 {color:yellow} |
100 |
通過上面,就可以很簡單的看出,HTML標(biāo)記的權(quán)重是1,CLASS的權(quán)重是10,ID的權(quán)重是100,繼承的權(quán)重為0(后面會講到)。
按這些規(guī)則將數(shù)字符串逐位相加,就得到最終的權(quán)重,然后在比較取舍時按照從左到右的順序逐位比較。
優(yōu)先級問題其實就是一個沖突解決的問題,當(dāng)同一個元素(內(nèi)容)被CSS選擇符選中時,就要按照優(yōu)先級取舍不同的CSS規(guī)則,這其中涉及到的問題其實很多。
說到這里,我們不得不說一下CSS的繼承性。
出處:W3C標(biāo)準(zhǔn)WEB前端DHTML精英俱樂部
責(zé)任編輯:bluehearts
上一頁 下一頁 為您解讀CSS優(yōu)先級 [2]
◎進(jìn)入論壇網(wǎng)頁制作、WEB標(biāo)準(zhǔn)化版塊參加討論,我還想發(fā)表評論。
|