CSS規則層疊時的優先順序演算法

來源:互聯網
上載者:User

 

CSS 規則的優先順序是Web前端開發人員必須理解的一個概念,我們常用的添加樣式的方法有4種。

  • inline style
  • embeded style
  • external style
  • user style

inline style是醜陋的,它們穿梭在HTML文檔中,與HTML元素扭成一團,給Web前端開發人員造成了許多麻煩。它們往往以這樣的面目出現:

<p style="color:red;">This is a paragraph.</p>

embeded style比inline style紳士一些,它們也寄宿在HTML文檔中,但是它們不屑於與HTML元素扭成一團。它們往往在 <style> 元素中出現:

<style type="text/css" media="screen">
p{
color : red;
}
</style>

external style是個貴族,它不願意同HTML呆在一起,所以乾脆以外部檔案的形式獨立存在。通常我們使用 <link> 元素或者@import語句將它們匯入HTML。

<link rel="stylesheet" type="text/css" href="style.css" media="screen" />

我們應當儘可能使用external style,我想理由有很多,大家都知道,我也就不重複了。

還有一種user style與以上三者略有不同,如果你使用IE瀏覽器,那麼你可以在Tools – Internet Options – General – Appearance – Accessibility – User style sheet 下找到添加user style的地方(原諒我沒有中文版的IE瀏覽器)。

既然我們有如此多的添加style的方法,那麼難以避免樣式會產生層疊。如:

<p class="intro" style="color:red;">This is a paragraph.</p>

我們在使用以上inline style的同時,又在我們的external style中使用了:

p{
color : yellow;
}

我們甚至還在擁有 class="intro"<p> 元素上應用了:

p.intro{
color : blue;
}

這樣我們就 在同一元素的同一屬性 color 上,擁有多條CSS規則指定了值 。這種情況被稱為層疊(Cascading)。當層疊發生時,CSS Parser將根據優先順序演算法來確定最終選用的值。

 

 

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.