|
即使在不太復(fù)雜的樣式表中,也可能會(huì)有兩個(gè)或者更多個(gè)規(guī)則找到同一元素。CSS通過一個(gè)叫做層疊(cascade)的過程處理這種沖突。層疊給每個(gè)規(guī)則分配一個(gè)重要程度指數(shù)。作者定義的樣式具有最高的重要性指數(shù),其次是用戶定義的樣式。但是為了增強(qiáng)用戶的控制能力,用戶可以通過為任何規(guī)則增加一個(gè)!important來提高它的重要性指數(shù),讓它的優(yōu)先級(jí)高于任何規(guī)則,甚至是比作者的!important還要高。
因此,層疊重要性指數(shù)的次序依次為:
標(biāo)記為!important的用戶樣式
標(biāo)記為!important的作者樣式
作者樣式
用戶樣式
瀏覽器/用戶代理的默認(rèn)樣式
為了計(jì)算規(guī)則的優(yōu)先級(jí),每種類型的選擇符都有一個(gè)相應(yīng)的數(shù)值,由于每個(gè)選擇器都由若干選擇符組成,所以選擇器的優(yōu)先指數(shù)由選擇符對(duì)應(yīng)的數(shù)值相加而成,數(shù)值越高,優(yōu)先級(jí)越高。CSS中的選擇符有四類:
行內(nèi)樣式(Inline Style),如<span style="color:red">...</span>
ID選擇符(ID selectors),如#myid
類、屬性選擇符、偽類(Classes, attributes and pseudo-classes),如 .class {...}、[href$=dudo.org]、:hover
元素(elements)、偽元素選擇符(pseudo-elements),如 p {...}、:first-line {...}
怎么來測(cè)量呢?如前所述,它們每一類都有不同的數(shù)值表示,其中:
行內(nèi)樣式為:1000
ID選擇符為:0100
類選擇符為:0010
元素樣式為:0001
這里要指出的是,所有這些數(shù)值都不是10進(jìn)制數(shù)字,1000只是代碼它是一個(gè)行內(nèi)樣式,
例如,body #wrap p {...},那么它的優(yōu)先級(jí)指數(shù)就是 1+100+1=102,而body div#wrap p {...}的優(yōu)先級(jí)指數(shù)就是 1+ 1 +100 + 1 =103。
再看一下其它的例子:
* { } 0
li:first-line { } 2 (one element, one pseudo-element)
ul ol+li { } 3 (three elements)
ul ol li.red { } 13 (one class, three elements)
style=”” 1000 (one inline styling)
div p { } 2 (two HTML selectors)
div p.sith { } 12 (two HTML selectors and a class selector)
body #darkside .sith p { } 112 (HTML selector, id selector, class selector, HTML selector; 1+100+10+1)
看這段代碼:
#wrap #content {color: blue;}
#content {color: red;}
。糳iv id="wrap">
。糳iv id="content">this is a text here</div>
。/div>
最終文本會(huì)顯示什么樣的顏色呢?
是的,樣式覆蓋只會(huì)發(fā)生在具有相同優(yōu)先級(jí)的情況下。這個(gè)例子中#wrap #content為200,而#content為100,縱使后設(shè)定color:red,也不會(huì)覆蓋掉先前設(shè)定的color:blue;。此外,你可以為#content {color: red;}增加!important來看看效果。
以上都是在少于10個(gè)選擇符的情況下,可以把這些數(shù)值當(dāng)作十進(jìn)制來使用和比較,但是,當(dāng)選擇符超過10個(gè)(雖然可能性很。┯謺(huì)怎么樣呢?我們參考一個(gè)Eric的例子:
.hello {color: red;} /* specificity = 10 */
HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI {color: green;}
/* specificity = 15 */
這里的10并不是“十”,它僅僅代表是一個(gè)煩選擇符,所以的它的優(yōu)先級(jí)依然要比 15個(gè)類型選擇符組成的選擇器要高。如果換成十六進(jìn)制的話,就是這個(gè)樣子
.hello {color: red;} /* specificity = 10 */
HTML BODY DIV UL LI OL LI UL LI OL LI UL LI OL LI {color: green;}
/* specificity = 15 */
但是問題,如果你再添加兩個(gè)元素,就又變成了11了,還是出現(xiàn)前面的情況。不過你應(yīng)該始終記得,即使數(shù)值“看起來”比較大,它們的排序首先按照類型優(yōu)先級(jí)來決定。
|
|
【收藏】【打印】【進(jìn)入論壇】 |
|
|
|
|
|
|
|