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