欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

CSS屬性簡寫和選擇器的優(yōu)先級問題

Libuchao's blog   發(fā)布時間:2015-08-15 16:59:43   作者:libuchao   我要評論
這篇文章主要介紹了CSS屬性簡寫和選擇器的優(yōu)先級問題,是CSS入門學(xué)習(xí)中的基礎(chǔ)知識,需要的朋友可以參考下

幾個常用 CSS 屬性的簡短寫法

精簡 CSS 代碼有很多種方法,但其中最常用的方法可能就是使用屬性的簡短形式。

具有簡短寫法的 CSS 屬性很多,但是常用的屬性無外乎字體、列表、背景、邊框、透明等幾種,所以在此對這幾種屬性的簡短寫法做個歸納,備忘。
font 屬性

font 屬性涉及到字體、字號、行高等好幾個屬性,使用簡短寫法的時候可以節(jié)省好多代碼量。雖然并非所有屬性都要定義,但是一般來說 font-size 和 font-family 是必不可少的,以下是 font 的幾個屬性與其對應(yīng)的默認(rèn)值:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* font 各屬性與默認(rèn)值 */  
  2. font-variantnormal;   
  3. line-heightnormal;   
  4. font-family: varies;   
  5. font-weightnormal;   
  6. font-stylenormal;   
  7. font-sizemedium;  

以上 6 個屬性可以合并成一行,根據(jù) W3C 規(guī)范,各屬性前后排列順序依次為:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* 字體各屬性前后順序 */  
  2. font: [font-style] [font-variant] [font-weight] [font-size]/[line-height] [font-family];  

再看以下幾個示例:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. font14px Georgia, serif;   
  2. font14px/1.4 Georgia, serif;   
  3. fontitalic lighter 14px/1.4 Georgia, serif;   
  4. fontitalic small-caps lighter 14px/1.4 Georgia, serif;  

可以看到,一行代碼就可以代替一段代碼,而且看起來還更優(yōu)雅一些,就是單獨查找某個屬性的時候有點不太方便,看著眼花。
list 屬性

list 有三個屬性,這三個屬性分別定義:type、image 和 position,它們的屬性名和默認(rèn)值分別如下:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. list-style-typedisc;   
  2. list-style-imagenone;   
  3. list-style-positionoutside;  

list 只有三個屬性,并不復(fù)雜,但是我們?nèi)匀豢梢詫⑦@三個屬性合并為在一行中,根據(jù) W3C 規(guī)范,寫法如下:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* list 屬性簡短寫法 */  
  2. list-style: [list-style-type] [list-style-position] [list-style-image];   
  3.   
  4. /* 示例 */  
  5. list-stylenone;   
  6. list-styledisc;   
  7. list-styledisc outside;   
  8. list-styledisc outside url(bg.png);  

一如既往的簡單,基本上就是簡寫了 list 屬性的名稱,然后按順序排列一下屬性的值即可。
background 屬性

很多樣式表中都會多次定義 background 屬性,每次都要重復(fù)其 5 個屬性的話,那代碼量可會成倍的增加呢。下面是其 5 個屬性名及其默認(rèn)值:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* background 的各屬性及其默認(rèn)值 */  
  2. background-attachmentscroll;   
  3. background-colortransparent;   
  4. background-positiontop left;   
  5. background-repeatrepeat;   
  6. background-imagenone;  

根據(jù) W3C 規(guī)范,將其 5 個屬性合并起來的寫法如下:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* background 屬性簡短寫法 */  
  2. background: [background-color] [background-image] [background-repeat] [background-attachment] [background-position];   
  3.   
  4. /* 示例 */  
  5. background#777;   
  6. backgroundurl(images/bg.png) 0 0;   
  7. background#777 url(images/bg.png) repeat-x 0 0;   
  8. background#777 url(images/bg.png) repeat-x fixed 0 0;  

對于 background 簡短寫法而言,不同的標(biāo)簽的使用方法和效果都有一些細(xì)微差別,欲知詳情者,請至官方文檔查看。
border 屬性

border 屬性更為簡單,它 3 個屬性以及默認(rèn)值如下:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* border 各屬性及其默認(rèn)值 */  
  2. border-widthnone;   
  3. border-stylenone;   
  4. border-colornone;  

根據(jù) W3C 規(guī)范,其簡短寫法如下:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. /* border 屬性簡短寫法 */  
  2. border: [border-width] [border-style] [border-color];   
  3.   
  4. /* 示例 */  
  5. border1px solid #111;   
  6. border2px dotted #222;   
  7. border3px dashed #333;  

當(dāng)然也可以為 4 個邊框定義不同的樣式:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. border-bottom1px solid #777;   
  2. border-right:  2px solid #111;   
  3. border-left:   2px solid #111;   
  4. border-top:    1px solid #777;  


CSS 選擇器的優(yōu)先級問題

CSS 意為層疊樣式表。所謂層疊,就是說,可以用多個 CSS 聲明來作用于同一元素,例如用一段 CSS 來定義文字的顏色,用另外一段 CSS 來定義文字的大小,最終達(dá)到樣式疊加的效果。

這種特性一定程度上使 CSS 可以更為方便的定義樣式,但同時也帶來了一定的復(fù)雜性。例如,當(dāng)多個樣式作用于同一個元素,而且還是作用于同一個屬性,元素最終會以何種方式來呈現(xiàn)樣式呢?

參考下面這個例子:

CSS Code復(fù)制內(nèi)容到剪貼板
  1. p {   
  2.  colorblack;   
  3.  background-colorwhite;   
  4. }   
  5. div.warning p {   
  6.  colorred;   
  7. }   
  8. div#caution p {   
  9.  coloryellow;   
  10. }   
  11. body#home div p {   
  12.  colorwhite;   
  13. }  

此樣式表中有 4 組選擇器,且最終都指向 p 元素,并且每組樣式中都有 color 屬性。這樣一來,可能的情況就是會有多個顏色屬性,被施加于同一個 p 元素。問題來了,瀏覽器最終會以什么樣的方式來渲染 p 的顏色呢?后定義的顏色會覆蓋掉先定義的顏色嗎?

這里就涉及到一個 CSS 選擇器優(yōu)先級的問題,如果有多個選擇器作用于某元素的同一個屬性,那么瀏覽器會去計算其對應(yīng)選擇器的優(yōu)先級,并最終將優(yōu)先級最高的那個選擇器的樣式作用于元素。
如何計算優(yōu)先級呢?

優(yōu)先級的計算通常遵循如下規(guī)則:

    如果某元素被設(shè)置了 style 屬性,也就是說被設(shè)置了行內(nèi)樣式,那么此行內(nèi)樣式將擁有最高的優(yōu)先級,任何其它外部樣式都不能將其覆蓋。如果沒有被設(shè)置行內(nèi)樣式,那么參照下面的第 2 條規(guī)則。
    數(shù)一下選擇器中 ID 選擇器的個數(shù),個數(shù)最多的,優(yōu)先級就最高。如果 ID 選擇器個數(shù)相同,或者壓根兒就沒有 ID 選擇器,那么參照下面的第 3 條規(guī)則。
    數(shù)一下類選擇器(如 .test)的個數(shù),屬性選擇器(如 [type="submit"])的個數(shù),還有偽類選擇器(如 :hover)的個數(shù),然后將個數(shù)加起來,總數(shù)最多的,這組選擇器的優(yōu)先級就最高。如果總是一樣多,或者都為 0,那么參照下面的第 4 條規(guī)則。
    數(shù)一下標(biāo)簽選擇器(如 p)的個數(shù),另外還有偽元素選擇器(如 :first-letter)的個數(shù),加起來,總數(shù)最多的,優(yōu)先級就最高。

如果經(jīng)過上面的計算,優(yōu)先級還是一樣高,那么遵循后出現(xiàn)的樣式覆蓋先出現(xiàn)的樣式之規(guī)則。

現(xiàn)在回過頭來看先前的例子,那四組選擇器的優(yōu)先級分別為 0001、0012、0102、0103,之所以把優(yōu)先級數(shù)字化,是因為這樣更方便比較。按照自然數(shù)法則(事實上它們并非自然數(shù))來比較,1 < 12 < 102 < 103,這樣一來,它們的優(yōu)先級孰高孰低,就一目了然了。

相關(guān)文章

  • CSS屬性簡寫整理

    在書寫css過程中盡量簡寫css屬性,有助于寫出高效整潔的css,本文將常用的一一列出,需要的朋友可以參考下
    2012-11-29
  • CSS中簡寫屬性要注意TRouBLe的順序問題(避免踩坑)

    這篇文章主要介紹了CSS中簡寫屬性要注意TRouBLe的順序問題(避免踩坑),本文通過實例代碼給大家介紹的非常詳細(xì),大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參
    2020-08-10

最新評論