瀏覽器如何判斷css優(yōu)先級
來源:易賢網(wǎng) 閱讀:1162 次 日期:2015-03-02 11:12:44
溫馨提示:易賢網(wǎng)小編為您整理了“瀏覽器如何判斷css優(yōu)先級”,方便廣大網(wǎng)友查閱!

概念

瀏覽器是通過判斷優(yōu)先級,來決定到底哪些屬性值是與元素最相關的,從而應用到該元素上。優(yōu)先級是由選擇器組成的匹配規(guī)則決定的。

如何計算?

優(yōu)先級是根據(jù)由每種選擇器類型構成的級聯(lián)字串計算而成的. 它不是一個對應相應匹配表達式的權重值.

如果優(yōu)先級相同,元素最終會應用 CSS 中靠后的聲明.

注意: 在文檔樹中的距離是不會對元素優(yōu)先級計算產(chǎn)生影響的.(可以看文檔中無視DOM樹中的距離的例子)

優(yōu)先級順序

下列是一份優(yōu)先級逐級增加的選擇器列表:

通用選擇器*

元素(類型)選擇器

類選擇器

屬性選擇器

偽類

ID 選擇器

內聯(lián)樣式

事實上,元素還可以從父元素上繼承一些樣式,如color等屬性。這些繼承的樣式的優(yōu)先級永遠低于元素本身的樣式,包括通用選擇器:

代碼如下:

<div id='test'>

<a href="#">text</a>

</div></p> <p> * {

color:red;

}

#test{

color:blue;

}

最終text的顏色是紅色的。

!important 規(guī)則是例外

當!important 規(guī)則被應用在一個樣式聲明中時,該樣式聲明會覆蓋CSS中任何其他的聲明, 無論它處在聲明列表中的哪個位置. 盡管如此, !important規(guī)則還是與優(yōu)先級毫無關系使用!important不是一個好習慣,因為它改變了你樣式表本來的級聯(lián)規(guī)則,從而難以調試。

一些不成文規(guī)則

不要在全站范圍的css中使用!important.

只在需要覆蓋全站范圍的css或是外部css(例如引用的ExtJs或是YUI)的時候才在指定的頁面上使用 !important。

不要在你的插件中使用!important。

永遠都要優(yōu)先考慮使用樣式規(guī)則的優(yōu)先級來解決問題而不是 !important。

取而代之,你可以:

更好的利用CSS的級聯(lián)屬性

更多的使用適合的選擇器。比如在你需要選定的對象元素前加上更多的元素,使選擇的范圍縮小,你的選擇器就變得更有針對性,從而提高優(yōu)先級:

代碼如下:

<div id="test">

<span>Text</span>

</div>

div#test span { color: green }

span { color: red }

div span { color: blue }

無論你c​ss語句的順序是什么樣的,文本都會是綠色的(green)因為這一條規(guī)則是最有特殊性、優(yōu)先級最高的。(同理,無論語句順序怎樣,藍色(blue)的規(guī)則都會覆蓋紅色(red)的規(guī)則)

什么時候應該使用:

A) 一種情況

你的網(wǎng)站上有一個設定了全站樣式的CSS文件,同時你(或是你同事)寫了一些效果通常都是很差的行內樣式(行內樣式的優(yōu)先級是最高的)。

在這種情況下,你就可以在你全局的CSS文件中寫一些!important的樣式來覆蓋掉那些直接寫在元素上的行內樣式。

活生生的例子比如:有人在jQuery插件里寫了糟糕的行內樣式。

B) 另一種情況

代碼如下:

#someElement p {

color: blue;

}

p.awesome {

color: red;

}

在外層有 #someElement 的情況下,你怎樣能使 awesome 的段落變成紅色呢?這種情況下,如果不使用!important,第一條規(guī)則永遠比第二條的優(yōu)先級更高。

怎樣覆蓋掉 !important

很簡單,你只需要再加一條 !important 的CSS語句,將其應用到更高優(yōu)先級的選擇器(在原有基礎上添加額外的標簽、class或id選擇器)上;或是保持選擇器一樣,但添加的位置需要在原有聲明的后面(優(yōu)先級相同的情況下,后邊定義的會覆蓋前邊定義的)。

代碼如下:

<div>

<a href="#" id="test">text</a>

</div>

想要把原有的綠色文本變成紅色,提升優(yōu)先級的方式:

代碼如下:

#test.a{

color: red !important;<!--盡管這條聲明在前,但是仍會覆蓋下邊的樣式-->

}

a{

color: green !important;

}

不過

代碼如下:

a{

color: green !important;

}

a{

color: red !important;<!--同樣的選擇器,后邊的聲明會覆蓋前邊的-->

}

更多信息請查看IT技術專欄

更多信息請查看腳本欄目
易賢網(wǎng)手機網(wǎng)站地址:瀏覽器如何判斷css優(yōu)先級

2025國考·省考課程試聽報名

  • 報班類型
  • 姓名
  • 手機號
  • 驗證碼
關于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機站點 | 投訴建議
工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務許可證:(云)人服證字(2023)第0102001523號
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關注公眾號:hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權所有:易賢網(wǎng)