解讀CSS優先級的概念和規則
本文向大家描述一下CSS優先級的概念和規則,在講CSS優先級之前,我們得要了解什么是CSS,CSS是用來做什么的。CSS是層疊樣式表(CascadingStyleSheets)的簡稱它的規范代表了互聯網歷史上一個獨特的發展階段。
解讀CSS優先級
在講CSS優先級之前,我們得要了解什么是CSS,CSS是用來做什么的。
首先,我們對CSS作一個簡單的說明:CSS是層疊樣式表(CascadingStyleSheets)的簡稱。它的規范代表了互聯網歷史上一個獨特的發展階段。現在對于從事網頁制作的朋友來說,應該很少沒有聽說過CSS了,因為在制作網頁過程中我們經常需要用到。
其次:我們能通過CSS為文檔設置豐富且易于修改的外觀,以減輕網頁制作者的工作負擔,從而減輕制作及后期維護的代價。其實現在還來講CSS是什么,CSS有什么作用完全是多余的,相信從事網頁制作的朋友都已經或多或少的接觸過了。
一、什么是CSS優先級?
所謂CSS優先級,即是指CSS樣式在瀏覽器中被解析的先后順序。
二、CSS優先級規則
既然樣式有優先級,那么就會有一個規則來約定這個優先級,而這個“規則”就是本次所需要講的重點。樣式表中的特殊性描述了不同規則的相對權重,它的基本規則是:
◆統計選擇符中的ID屬性個數。
◆統計選擇符中的CLASS屬性個數。
◆統計選擇符中的HTML標記名個數。
***,按正確的順序寫出三個數字,不要加空格或逗號,得到一個三位數(css2.1是用4位數表示)。(注意,你需要把數字轉換成一個以三個數字結尾的更大的數)。相應于選擇符的最終數字列表可以很容易確定較高數字特性凌駕于較低數字的。
三、附加說明
文內的樣式優先級為1,0,0,0,所以始終高于外部定義。這里文內樣式指形如<divstyle="color:red">blah</div>的樣式,而外部定義指經由<link>或<style&gt;卷標定義的規則。
有!important聲明的規則高于一切。
如果!important聲明沖突,則比較優先權。
如果優先權一樣,則按照在源碼中出現的順序決定,后來者居上。
由繼承而得到的樣式沒有specificity的計算,它低于一切其它規則(比如全局選擇符*定義的規則)。
關于經由@import加載的外部樣式,由于@import必須出現在所有其它規則定義之前(如不是,則瀏覽器應該忽略之),所以按照后來居上原則,一般優先權沖突時是占下風的。
還需要說一下,IE是可以識別位置錯誤的@import的,但無論@import在什么地方,它都認為是位于所有其它規則定義之前的,這可能會引發一些誤會。
優先權問題看起來簡單,但背后還是有非常復雜的機制,在實際應用中需要多多留意。
詳文參考:http://www.mypchelp.cn/it/20091015/webdesign_152443.shtml
【編輯推薦】