国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發(fā) > CSS > 正文

CSS樣式表層疊(cascade)處理沖突

2024-07-11 08:43:04
字體:
來源:轉載
供稿:網(wǎng)友

原文連接:http://www.dudo.org/article.asp?id=252
即使在不太復雜的樣式表中,也可能會有兩個或者更多個規(guī)則找到同一元素。CSS通過一個叫做層疊(cascade)的過程處理這種沖突。層疊給每個規(guī)則分配一個重要程度指數(shù)。作者定義的樣式具有最高的重要性指數(shù),其次是用戶定義的樣式。但是為了增強用戶的控制能力,用戶可以通過為任何規(guī)則增加一個!important來提高它的重要性指數(shù),讓它的優(yōu)先級高于任何規(guī)則,甚至是比作者的!important還要高。
因此,層疊重要性指數(shù)的次序依次為:
    標記為!important的用戶樣式
    標記為!important的作者樣式
    作者樣式
    用戶樣式
    瀏覽器/用戶代理的默認樣式
    為了計算規(guī)則的優(yōu)先級,每種類型的選擇符都有一個相應的數(shù)值,由于每個選擇器都由若干選擇符組成,所以選擇器的優(yōu)先指數(shù)由選擇符對應的數(shù)值相加而成,數(shù)值越高,優(yōu)先級越高。CSS中的選擇符有四類: 行內樣式(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 {...}
    怎么來測量呢?如前所述,它們每一類都有不同的數(shù)值表示,其中:
    行內樣式為:1000
    ID選擇符為:0100
    類選擇符為:0010
    元素樣式為:0001

    這里要指出的是,所有這些數(shù)值都不是10進制數(shù)字,1000只是代碼它是一個行內樣式,
    例如,body #wrap p {...},那么它的優(yōu)先級指數(shù)就是 1 100 1=102,而body div#wrap p {...}的優(yōu)先級指數(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)

    看這段代碼:
    1. #wrap#content{color:blue;}
    2. #content{color:red;}


    1. <divid="wrap">
    2. <divid="content">thisisatexthere</div>
    3. </div>

    4. 最終文本會顯示什么樣的顏色呢?
      是的,樣式覆蓋只會發(fā)生在具有相同優(yōu)先級的情況下。這個例子中#wrap #content為200,而#content為100,縱使后設定color:red,也不會覆蓋掉先前設定的color:blue;。此外,你可以為#content {color: red;}增加!important來看看效果。
      以上都是在少于10個選擇符的情況下,可以把這些數(shù)值當作十進制來使用和比較,但是,當選擇符超過10個(雖然可能性很小)又會怎么樣呢?我們參考一個Eric的例子:
    1. .hello{color:red;}/*specificity=10*/
    2. HTMLBODYDIVULLIOLLIULLIOLLIULLIOLLI{color:green;}
    3. /*specificity=15*/
      這里的10并不是“十”,它僅僅代表是一個煩選擇符,所以的它的優(yōu)先級依然要比 15個類型選擇符組成的選擇器要高。如果換成十六進制的話,就是這個樣子
    1. .hello{color:red;}/*specificity=10*/
    2. HTMLBODYDIVULLIOLLIULLIOLLIULLIOLLI{color:green;}
    3. /*specificity=15*/
      但是問題,如果你再添加兩個元素,就又變成了11了,還是出現(xiàn)前面的情況。不過你應該始終記得,即使數(shù)值“看起來”比較大,它們的排序首先按照類型優(yōu)先級來決定。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 池州市| 封开县| 高邑县| 五指山市| 鹤庆县| 鄄城县| 革吉县| 邹城市| 故城县| 西乌珠穆沁旗| 明光市| 同仁县| 石嘴山市| 贵德县| 岱山县| 连山| 永川市| 桐城市| 百色市| 阿勒泰市| 道孚县| 定州市| 莱西市| 那曲县| 晋州市| 甘南县| 滨州市| 沅江市| 威远县| 达州市| 壶关县| 贵德县| 新郑市| 临沧市| 揭阳市| 筠连县| 安义县| 鹰潭市| 毕节市| 富川| 揭阳市|