[讀書筆記] CSS權威指南2: 結構和層疊

来源:http://www.cnblogs.com/philipding/archive/2016/04/24/5426619.html
-Advertisement-
Play Games

層疊樣式表中最基本的一個方面可能就是層疊——衝突的聲明要通過這個層疊過程排序,並由此確定最終的文檔表示。這個過程的核心是選擇器及其相關聲明的特殊性,以及繼承機制。 特殊性 對於每個規則,用戶代理會計算選擇器的特殊性,並將這個特殊性附加到規則中的各個聲明。如果一個元素有兩個或多個衝突的屬性聲明,那麼有 ...


層疊樣式表中最基本的一個方面可能就是層疊——衝突的聲明要通過這個層疊過程排序,並由此確定最終的文檔表示。這個過程的核心是選擇器及其相關聲明的特殊性,以及繼承機制。

特殊性

對於每個規則,用戶代理會計算選擇器的特殊性,並將這個特殊性附加到規則中的各個聲明。如果一個元素有兩個或多個衝突的屬性聲明,那麼有最高特殊性的聲明就會勝出。

選擇器的特殊性由選擇器本身的組件確定。特殊性值表述為4個部分,如:0,0,0,0。一個選擇器的具體特殊性如下確定:

對於選擇器中給定的各個ID屬性值,加0,1,0,0。

對於選擇器中給定的各個類屬性值,屬性選擇或偽類,加0,0,1,0。

對於選擇器中給定的各個元素和偽元素,加0,0,0,1。

內聯樣式,加1,0,0,0。

結合符和通配符選擇器對特殊性沒有任何貢獻

h1{color:red;}/* specifity = 0,0,0,1 */
p em{color:purple;}/* specifity = 0,0,0,2 */
.grape{color:purple;}/* specifity = 0,0,1,0 */
*.bright{color:yellow;}/* specifity = 0,0,1,0 */
p.bright em.dark{color:maroon;}/* specifity = 0,0,2,2 */
#id216{color:blue;}/* specifity = 0,1,0,0 */
div#sidebar *[href]{color:silver;}/* specifity = 0,1,1,1 */
h1+p{color:black;font-style:italic;}/* specifity = 0,0,0,2 */
<h1 style="color:green;">Green</h1> /* specifity = 1,0,0,0*/

重要性

CSS允許在這些聲明的結束分號之前插入 !important 來標誌。

p.dark {color:#333 !important; background: white;}

標誌為!important的聲明並沒有特殊的特殊性值,不過要與非重要聲明分開考慮。實際上,所有!important聲明會分組在一起,重要聲明的特殊性衝突會在重要聲明內部解決,而不會與非重要聲明相混。如果一個重要聲明和一個非重要聲明衝突,勝出的總是重要聲明。

繼承

樣式不僅應用到指定的元素,還會應用到它的後代元素。

/*
將聲明color :gray;應用到ul元素時,這個元素會採用該聲明。這個值再沿著樹向下傳播到後代元素,並一直繼續,直到再沒有更多的後代元素繼承這個值為止。值絕對不會向上傳播,也就是說,元素不會把值向上傳遞到其祖先。
*/
/*
註意:在HTML中,對於向上傳播規則有一個例外:應用到body元素的背景樣式可以傳遞到html元素(html是文檔的根元素),相應地可以定義其畫布。
*/
ul {
    color: red;
}

一般地,大多數框模型屬性(包括外邊距、內邊距、背景和邊框)不能繼承。

繼承的值根本沒有特殊性,甚至連0特殊性都沒有。

只要id為toolbar的元素只包含純文本而不包含其他內容,這就能正常起作用。不過,如果這個元素中的文本都是超鏈接(a元素),用戶代理的超鏈接樣式就會占上風。在一個Web瀏覽器中,這意味著它們的顏色很可能是藍色,因為瀏覽器的樣式表可能包含以下規則:

a:link {color: blue;}

為剋服這個問題,必須如下聲明:

#toolbar {color: white; background: black;}

#toolbar a:link {color: white;}通過向工具條中的a元素直接指定規則才可以覆蓋預設的規則了。

而通配選擇器具有0特殊性,所以一旦應用了通配選擇器,它就會覆蓋繼承的值,所以通配選擇器往往有一種短路繼承的效果。這說明不加區別的使用通配選擇器可能存在奇怪的問題。

層疊

  1. 按顯式權重對應用到該元素的所有聲明排序。標誌!important的規則的權重要高於沒有!important標誌的規則。
  2. 按來源對應用到給定元素的所有聲明排序。共有3種來源:創作人員、讀者和用戶代理。正常情況下,創作人員的樣式要勝過讀者的樣式。有!important標誌的讀者樣式要強乾所有其他樣式,這包括有!important標誌的創作人員樣式。創作人員樣式和讀者樣式都比用戶代理的預設樣式要強。
    1. 讀者的!important樣式
    2. 創作者的!important樣式
    3. 創作者的正常樣式
    4. 讀者的正常樣式
    5. 用戶代理聲明的樣式
  3. 按特殊性對應用到給定元素的所有聲明排序。有較高特殊性的元素權重要大於有較低特殊性的元素。
  4. 按出現順序對應用到給定元素的所有聲明排序。一個聲明在樣式表或文檔中越後出現,它的權重就越大。如果樣式表中有導入的樣式表,一般認為出現在導入樣式表中的聲明在前,主樣式表中的所有聲明在後。

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 數據共用和數據傳遞是相輔相成的,我們一起來討論這個問題。首先要說的是共用和傳遞都是有作用域的。作用域就是起作用的區域,在同一個作用域數據可以共用,超過這個作用域就是跨作用域,就得用到數據傳遞了。 作用域 ui作用域每一個ui文件預設都有對應的ui.js。他們作為一個閉合的作用域。ui.js里根據ui ...
  • 學習要點: 1.HTML5 文檔結構 2.文檔結構解析 3.元素標簽探討 主講教師:李炎恢 本章主要先從 HTML5 的文檔結構談起。 這些基礎元素確定了 HTML 文檔的輪廓以及瀏覽器的初始環境。幾乎所有頁面都必須首先鍵入這些元素。 一.HTML5 文檔結構 1.第一步:打開 Sublime Te ...
  • 我們來個例子,一個HTML里包含一段文本和一個無序的列表。 上面例子里,我們使用getElementById DOM方法來訪問p段落,在SCRIPT里添加如下代碼: 變數introParagraph現在已經引用到該DOM節點上了,我們可以對該節點做很多事情,比如查詢內容和屬性,或者其它任何操作,甚至 ...
  • DOM
    DOM對象**1.屬性** docment.title 返回當前文檔的標題docment.URL 返迴文檔完整的URLdocument.bgColor 背景色document.fgColor 前景色 **2.方法** 2.1 document.getElementById(“elementID”); ...
  • 學習要點: 1.HTML5 的歷史 2.HTML5 的功能 3.HTML5 的特點 4.課程學習問題 主講教師:李炎恢 HTML5 是繼 HTML4.01 和 XHTML1.0 之後的超文本標記語言的最新版本。 它是由一群自由思想者組成的團隊設計出來,並最終實現多媒體支持、交互性、更加智能的表單,以 ...
  • 在bootstrap框架中將導航獨立出來成為一個導航組件,根據不同的版本,可以找到相應的源碼: LESS: navs.less SASS: _navs.scss 標簽形導航,也稱選項卡導航 標簽形導航是通過.nav-tabs樣式來實現的,在製作標簽形導航時需要在原導航類名為.nav的容器上追加類名. ...
  • 一、寫在最前面 最近都忙一些雜七雜八的事情,複習軟考、研讀經典...好像都好久沒寫過博客了。。。 我自己寫過三個圖片輪播,一個是簡單的原生JS實現的,沒有什麼動畫效果的,一個是結合JQuery實現的,淡入淡出切換的。現在想做一個酷一點的放在博客或者個人網站,到時候可以展示自己的作品。逛了一下慕課網, ...
  • 按鈕下拉菜單 按鈕下拉菜單僅從外觀上看和下拉菜單效果基本上是一樣的。它們唯一的不同是外部容器div.dropdown換成了div.btn-group bootstrap.css文件 按鈕的向下向上三角形 按鈕的向下三角形,是通過在button標簽中添加span標簽元素,且類名為.caret 這個三角 ...
一周排行
    -Advertisement-
    Play Games
  • 示例項目結構 在 Visual Studio 中創建一個 WinForms 應用程式後,項目結構如下所示: MyWinFormsApp/ │ ├───Properties/ │ └───Settings.settings │ ├───bin/ │ ├───Debug/ │ └───Release/ ...
  • [STAThread] 特性用於需要與 COM 組件交互的應用程式,尤其是依賴單線程模型(如 Windows Forms 應用程式)的組件。在 STA 模式下,線程擁有自己的消息迴圈,這對於處理用戶界面和某些 COM 組件是必要的。 [STAThread] static void Main(stri ...
  • 在WinForm中使用全局異常捕獲處理 在WinForm應用程式中,全局異常捕獲是確保程式穩定性的關鍵。通過在Program類的Main方法中設置全局異常處理,可以有效地捕獲並處理未預見的異常,從而避免程式崩潰。 註冊全局異常事件 [STAThread] static void Main() { / ...
  • 前言 給大家推薦一款開源的 Winform 控制項庫,可以幫助我們開發更加美觀、漂亮的 WinForm 界面。 項目介紹 SunnyUI.NET 是一個基於 .NET Framework 4.0+、.NET 6、.NET 7 和 .NET 8 的 WinForm 開源控制項庫,同時也提供了工具類庫、擴展 ...
  • 說明 該文章是屬於OverallAuth2.0系列文章,每周更新一篇該系列文章(從0到1完成系統開發)。 該系統文章,我會儘量說的非常詳細,做到不管新手、老手都能看懂。 說明:OverallAuth2.0 是一個簡單、易懂、功能強大的許可權+可視化流程管理系統。 有興趣的朋友,請關註我吧(*^▽^*) ...
  • 一、下載安裝 1.下載git 必須先下載並安裝git,再TortoiseGit下載安裝 git安裝參考教程:https://blog.csdn.net/mukes/article/details/115693833 2.TortoiseGit下載與安裝 TortoiseGit,Git客戶端,32/6 ...
  • 前言 在項目開發過程中,理解數據結構和演算法如同掌握蓋房子的秘訣。演算法不僅能幫助我們編寫高效、優質的代碼,還能解決項目中遇到的各種難題。 給大家推薦一個支持C#的開源免費、新手友好的數據結構與演算法入門教程:Hello演算法。 項目介紹 《Hello Algo》是一本開源免費、新手友好的數據結構與演算法入門 ...
  • 1.生成單個Proto.bat內容 @rem Copyright 2016, Google Inc. @rem All rights reserved. @rem @rem Redistribution and use in source and binary forms, with or with ...
  • 一:背景 1. 講故事 前段時間有位朋友找到我,說他的窗體程式在客戶這邊出現了卡死,讓我幫忙看下怎麼回事?dump也生成了,既然有dump了那就上 windbg 分析吧。 二:WinDbg 分析 1. 為什麼會卡死 窗體程式的卡死,入口門檻很低,後續往下分析就不一定了,不管怎麼說先用 !clrsta ...
  • 前言 人工智慧時代,人臉識別技術已成為安全驗證、身份識別和用戶交互的關鍵工具。 給大家推薦一款.NET 開源提供了強大的人臉識別 API,工具不僅易於集成,還具備高效處理能力。 本文將介紹一款如何利用這些API,為我們的項目添加智能識別的亮點。 項目介紹 GitHub 上擁有 1.2k 星標的 C# ...