在講CSS優先權之前,我們得要了解什麼是CSS,CSS是用來做什麼的。
首先,我們對CSS作一個簡單的說明:CSS是層疊樣式表(Cascading Style Sheets)的簡稱。它的規範代表了網路歷史上一個獨特的發展階段。現在對於從事網頁製作的朋友來說,應該很少沒有聽過CSS了,因為在製作網頁過程中我們常常需要用到。
其次:我們能透過CSS為文件設定豐富且易於修改的外觀,以減輕網頁製作者的工作負擔,進而減輕製作及後製的代價。
其實現在還來講CSS是什麼,CSS有什麼作用完全是多餘的,相信從事網頁製作的朋友都已經或多或少的接觸過了。
言歸正傳,我們開始進入今天的話題:
一、什麼是CSS優先權?
所謂CSS優先權,即是指CSS樣式在瀏覽器中被解析的先後順序。
二、CSS優先權規則
既然樣式有優先級,那麼就會有一個規則來約定這個優先級,而這個「規則」就是本次所需要講的重點。
樣式表中的特殊性描述了不同規則的相對權重,它的基本規則是:
最後,按正確的順序寫出三個數字,不要加空格或逗號,得到一個三位數(css2.1是用4位數表示)。 ( 注意,你需要把數字轉換成一個以三個數字結尾的更大的數字)。相應於選擇符的最終數字列表可以很容易地確定較高的數字特性凌駕於較低數字。
例如:
三、特性分類的選擇符列表
以下是一個按特性分類的選擇符的清單:
選擇符 | 特性值 |
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標記的權重是1,CLASS的權重是10,ID的權重是100,繼承的權重為0(後面會講到)。
依這些規則將數字串逐位相加,就得到最終的權重,然後在比較取捨時按照從左到右的順序逐位比較。
優先問題其實就是一個衝突解決的問題,當同一個元素(內容)被CSS選擇符選中時,就要按照優先級取捨不同的CSS規則,這其中涉及到的問題其實很多。
說到這裡,我們不得不說一下CSS的繼承性。