您好,登錄后才能下訂單哦!
這篇文章主要為大家展示了“網頁css優先級的示例分析”,內容簡而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領大家一起研究并學習一下“網頁css優先級的示例分析”這篇文章吧。
在講CSS優先級之前,我們得要了解什么是CSS,CSS是用來做什么的。
首先,我們對CSS作一個簡單的說明:CSS是層疊樣式表(Cascading Style Sheets)的簡稱。它的規范代表了互聯網歷史上一個獨特的發展階段。現在對于從事網頁制作的朋友來說,應該很少沒有聽說過CSS了,因為在制作網頁過 程中我們經常需要用到。
其次:我們能通過CSS為文檔設置豐富且易于修改的外觀,以減輕網頁制作者的工作負擔,從而減輕制作及后期維護的代價。
其實現在還來講CSS是什么,CSS有什么作用完全是多余的,相信從事網頁制作的朋友都已經或多或少的接觸過了。
一、什么是CSS優先級?
所謂CSS優先級,即是指CSS樣式在瀏覽器中被解析的先后順序。
二、CSS優先級規則
既然樣式有優先級,那么就會有一個規則來約定這個優先級,而這個“規則”就是本次所需要講的重點。
樣式表中的特殊性描述了不同規則的相對權重,它的基本規則是:
統計選擇符中的ID屬性個數。
統計選擇符中的CLASS屬性個數。
統計選擇符中的HTML標記名個數。
最后,按正確的順序寫出三個數字,不要加空格或逗號,得到一個三位數(css2.1是用4位數表示)。( 注意,你需要把數字轉換成一個以三個數字結尾的更大的數)。相應于選擇符的最終數字列表可以很容易確定較高數字特性凌駕于較低數字的。
例如:
每個ID選擇符(#someid),加 0,1,0,0。
每個class選擇符(.someclass)、每個屬性選擇符(形如[attr=value]等)、每個偽類(形如:hover等)加0,0,1,0。
每個元素或偽元素(:firstchild)等,加0,0,0,1。
其它選擇符包括全局選擇符*,加0,0,0,0。相當于沒加,不過這也是一種specificity,后面會解釋。
三、特性分類的選擇符列表
以下是一個按特性分類的選擇符的列表:
選擇符 | 特性值 |
h2 {color:blue;} | 1 |
p em {color:purple;} | 2 |
.apple {color:red;} | 10 |
p.bright {color:yellow;} | 11 |
p.bright em.dark {color:brown;} | 22 |
#id316 {color:yellow} | 100 |
單從上面這個表來看,貌似不大好理解,下面再給出一張表:
選擇符 | 特性值 |
h2 {color:blue;} | 1 |
p em {color:purple;} | 1+1=2 |
.apple {color:red;} | 10 |
p.bright {color:yellow;} | 1+10=11 |
p.bright em.dark {color:brown;} | 1+10+1+10=22 |
#id316 {color:yellow} | 100 |
通過上面,就可以很簡單的看出,HTML標記的權重是1,CLASS的權重是10,ID的權重是100,繼承的權重為0(后面會講到)。
按這些規則將數字符串逐位相加,就得到最終的權重,然后在比較取舍時按照從左到右的順序逐位比較。
優先級問題其實就是一個沖突解決的問題,當同一個元素(內容)被CSS選擇符選中時,就要按照優先級取舍不同的CSS規則,這其中涉及到的問題其實很多。
說到這里,我們不得不說一下CSS的繼承性。
網頁中加載多個css樣式文件,其中一個是Ext庫自帶的樣式文件,里面對所有標簽定義了一些樣式,導致原有網頁顯示不正確。通過找到對應樣式,重新設置了正確的樣式。將新樣式加到body標簽上,但是出現兩個樣式,Ext樣式仍然有效。最后發現時在設置新樣式的時候沒有加*,導致只對body標簽有用,而對子標簽無效。下面為修改后的樣式
代碼如下:
.diy,
.diy *{
box-sizing: content-box;
-moz-box-sizing : content-box;
-webkit-box-sizing: content-box;
}
當一個標簽被定義多個樣式,而樣式之間出現沖突時,優先級為“針對ID定義的樣式” > “類定義樣式” > “針對標簽類型定義的樣式”。例如下面幾個樣式
代碼如下:
div{
border:2px solid #0000FF;
}
.powerHeader{
border:2px solid #00ff00;
}
#navigation{
border:2px solid #ff0000;
}
在標簽<div id="navigation" class="powerHeader">,首先應用的是#navigation,當#navigation不存在時應用.powerHeader樣式,最后才是div樣式。
同時,單使用link或style定義多個標簽類class之間出現沖突時,會應用定義在最后的那個類。
了解css樣式優先級,能夠在網頁開發中避免許多樣式沖突問題。
以上是“網頁css優先級的示例分析”這篇文章的所有內容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內容對大家有所幫助,如果還想學習更多知識,歡迎關注億速云行業資訊頻道!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。