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

首頁 > 開發 > CSS > 正文

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

2024-07-11 08:21:13
字體:
來源:轉載
供稿:網友

原文連接:http://www.dudo.org/article.asp?id=252

即使在不太復雜的樣式表中,也可能會有兩個或者更多個規則找到同一元素。css通過一個叫做層疊(cascade)的過程處理這種沖突。層疊給每個規則分配一個重要程度指數。作者定義的樣式具有最高的重要性指數,其次是用戶定義的樣式。但是為了增強用戶的控制能力,用戶可以通過為任何規則增加一個!important來提高它的重要性指數,讓它的優先級高于任何規則,甚至是比作者的!important還要高。

    因此,層疊重要性指數的次序依次為:

  • 標記為!important的用戶樣式
  • 標記為!important的作者樣式
  • 作者樣式
  • 用戶樣式
  • 瀏覽器/用戶代理的默認樣式
    為了計算規則的優先級,每種類型的選擇符都有一個相應的數值,由于每個選擇器都由若干選擇符組成,所以選擇器的優先指數由選擇符對應的數值相加而成,數值越高,優先級越高。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 {...}
    怎么來測量呢?如前所述,它們每一類都有不同的數值表示,其中:
行內樣式為:1000
id選擇符為:0100
類選擇符為:0010
元素樣式為:0001


  這里要指出的是,所有這些數值都不是10進制數字,1000只是代碼它是一個行內樣式,

    例如,body #wrap p {...},那么它的優先級指數就是 1+100+1=102,而body div#wrap p {...}的優先級指數就是 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 {colorblue;}  
  2.     #content {colorred;}     

  1.   <div id="wrap">  
  2.     <div id="content">this is a text here</div>  
  3.   </div>  
  4.   
    最終文本會顯示什么樣的顏色呢?

      是的,樣式覆蓋只會發生在具有相同優先級的情況下。這個例子中#wrap #content為200,而#content為100,縱使后設定color:red,也不會覆蓋掉先前設定的color:blue;。此外,你可以為#content {color: red;}增加!important來看看效果。

        以上都是在少于10個選擇符的情況下,可以把這些數值當作十進制來使用和比較,但是,當選擇符超過10個(雖然可能性很小)又會怎么樣呢?我們參考一個eric的例子:
  1. .hello {colorred;}    /* specificity = 10 */  
  2.    html body div ul li ol li ul li ol li ul li ol li {colorgreen;}  
  3.                            /* specificity = 15 */  
    這里的10并不是“十”,它僅僅代表是一個煩選擇符,所以的它的優先級依然要比 15個類型選擇符組成的選擇器要高。如果換成十六進制的話,就是這個樣子
  1. .hello {colorred;}    /* specificity = 10 */  
  2.    html body div ul li ol li ul li ol li ul li ol li {colorgreen;}  
  3.                            /* specificity = 15 */   
        但是問題,如果你再添加兩個元素,就又變成了11了,還是出現前面的情況。不過你應該始終記得,即使數值“看起來”比較大,它們的排序首先按照類型優先級來決定。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 桃江县| 盐山县| 水富县| 隆昌县| 蚌埠市| 铜梁县| 乾安县| 和政县| 英吉沙县| 华阴市| 突泉县| 共和县| 女性| 亳州市| 治县。| 肇庆市| 宿州市| 瑞安市| 广饶县| 桦甸市| 巧家县| 获嘉县| 盐山县| 古丈县| 专栏| 莱州市| 灵川县| 巢湖市| 镇赉县| 商都县| 图们市| 沂南县| 马龙县| 正安县| 弥勒县| 莒南县| 德格县| 南召县| 华阴市| 商河县| 芜湖市|