米利唐_后腰_乌克兰足球超级联赛_中国竞彩欧赔 - 足球竞彩分析

集團(tuán)官網(wǎng)
  • 國(guó)家級(jí)全民數(shù)字素養(yǎng)與技能培訓(xùn)基地
  • 河南省第一批產(chǎn)教融合型企業(yè)建設(shè)培育單位
  • 鄭州市數(shù)字技能人才(碼農(nóng))培養(yǎng)評(píng)價(jià)聯(lián)盟

CSS樣式優(yōu)先級(jí)是怎樣劃分的?

編輯:云和數(shù)據(jù) 日期:2023-05-31 09:19

定義CSS樣式時(shí),經(jīng)常出現(xiàn)兩個(gè)或更多樣式規(guī)則應(yīng)用在同一元素上的情況。此時(shí)CSS就會(huì)根據(jù)樣式規(guī)則的權(quán)重,優(yōu)先顯示權(quán)重最高的樣式。CSS優(yōu)先級(jí)指的就是CSS樣式規(guī)則的權(quán)重。在網(wǎng)頁制作中,CSS為每個(gè)基礎(chǔ)選擇器都指定了不同的權(quán)重,方便我們添加樣式代碼。為了深入理解CSS優(yōu)先級(jí),我們通過一段示例代碼進(jìn)行分析。CSS樣式代碼如下:

p{?color:red;}???????????/*標(biāo)簽樣式*/.blue{?color:green;}?????/*class樣式*/theader{?color:blue;}????/*id樣式*/

CSS樣式代碼對(duì)應(yīng)的HTML結(jié)構(gòu)為:

????幫幫我,我到底顯示什么顏色?

在上面的示例代碼中,使用不同的選擇器對(duì)同一個(gè)元素設(shè)置文本顏色,這時(shí)瀏覽器會(huì)根據(jù)CSS選擇器的優(yōu)先級(jí)規(guī)則解析CSS樣式。為了便于判斷元素的優(yōu)先級(jí),CSS為每一種基礎(chǔ)選擇器都分配了一個(gè)權(quán)重,我們可以通過虛擬數(shù)值的方式為這些基礎(chǔ)選擇器匹配權(quán)重。假設(shè)標(biāo)簽選擇器具有權(quán)重為1.類選擇器具有權(quán)重則為10,id選擇器具有權(quán)重則為l00。這樣id選擇器“#header”就具有最大的優(yōu)先級(jí),因此文本顯示為藍(lán)色。

對(duì)于由多個(gè)基礎(chǔ)選擇器構(gòu)成的復(fù)合選擇器(并集選擇器除外),其權(quán)重可以理解為這些基礎(chǔ)選擇器權(quán)重的疊加。例如,下面的CSS代碼。

p?strong{color:black}????????????/*權(quán)重為:1+1*/strong.blue{color:green;}????????/*權(quán)重為:1+10*/.father?strong{color:yellow}?????/*權(quán)重為:10+1*/p.father?strong{color:orange;}???/*權(quán)重為:1+10+1*/p.father?.blue{color:gold;}??????/*權(quán)重為:1+10+10*/theader?strong{color:pink;}??????/*權(quán)重為:100+1*/#header?strong.blue{color:red;}??/*權(quán)重為:100+1+10*/

對(duì)應(yīng)的HTML結(jié)構(gòu)為:

????文本的顏色

這時(shí),CsS代碼中的“#header strong.blue”選擇器的權(quán)重最高,文本顏色將顯示為紅色。此外,在考慮權(quán)重時(shí),我們還需要注意一些特殊的情況。

(1)繼承樣式的權(quán)重為0

在嵌套結(jié)構(gòu)中、h不管父元素樣式的權(quán)重多大,被子元素繼承時(shí),它的權(quán)重都為0,也就是說子元素定義的樣式會(huì)覆蓋繼承來的樣式。例如,下面的CSS樣式代碼。

strong{color:red;}#header{color:green;}

CSS樣式代碼對(duì)應(yīng)的HTML結(jié)構(gòu)如下:

??繼承樣式不如自己定義的權(quán)重大

在上面的代碼中,雖然“#header”具有權(quán)重100,但被標(biāo)簽繼承時(shí)權(quán)重為0。而“strong”選擇器的權(quán)重雖然僅為1,但它大于繼承樣式的權(quán)重,所以頁面中的文本顯示為紅色。

(2)行內(nèi)樣式優(yōu)先

應(yīng)用style屬性的元素,其行內(nèi)樣式的權(quán)重非常高。換算為數(shù)值,我們可以理解為遠(yuǎn)大于100。因此行內(nèi)樣式擁有比上面提到的選擇器都高的優(yōu)先級(jí)。

(3)權(quán)重相同時(shí),CSS的優(yōu)先級(jí)遵循就近原則

也就是說,靠近元素的樣式具有最大的優(yōu)先級(jí),或者說按照代碼排列上下順序,排在最下邊的樣式優(yōu)先級(jí)最大。例如,下面為外部定義的CSS示例代碼。

/*CSS文檔,文件名為style_red.css*/#header{color:red;}?????????????????????/*外部樣式*/

對(duì)應(yīng)的HTML結(jié)構(gòu)代碼如下:

CSS優(yōu)先級(jí)?/*引入外部定義的CSS代碼*/#header{color:gray;}/*內(nèi)嵌式樣式*/權(quán)重相同時(shí),就近優(yōu)先

在上面的示例代碼中,第2行代碼通過外鏈?zhǔn)揭隒SS樣式,該樣式設(shè)置文本樣式顯示為紅色。第3~5行代碼通過內(nèi)嵌式引入CSS樣式,該樣式設(shè)置文本樣式顯示為灰色。

上面的頁面被解析后,段落文本將顯示為灰色,即內(nèi)嵌式樣式優(yōu)先。這是因?yàn)閮?nèi)嵌樣式比外鏈?zhǔn)綐邮礁拷麳TML.元素。同樣的道理,如果同時(shí)引用兩個(gè)外部樣式表,則排在下面的樣式表具有較大的優(yōu)先級(jí)。如果此時(shí)將內(nèi)嵌樣式更改為:

p{color:gray;}???????????????????/*內(nèi)嵌式樣式*/

此時(shí)外鏈?zhǔn)降膇d選擇器和嵌入式的標(biāo)簽選擇器權(quán)重不同,“#header”的權(quán)重更高,文字將顯示為外部樣式定義的紅色。

(4)CSS定義“l(fā)important”命令,會(huì)被賦予最大的優(yōu)先級(jí)

當(dāng)CSS定義了“l(fā)important”命令后,將不再考慮權(quán)重和位置關(guān)系,使用“l(fā)important”的標(biāo)簽都具有最大優(yōu)先級(jí)。例如,下面的示例代碼。

#header{color:red!important;}

應(yīng)用此樣式的段落文本顯示為紅色,因?yàn)椤發(fā)important”命令的樣式擁有最大的優(yōu)先級(jí)。需要注意的是,“l(fā)important”命令必須位于屬性值和分號(hào)之間,否則無效。

復(fù)合選擇器的權(quán)重為組成它的基礎(chǔ)選擇器權(quán)重的疊加,但是這種疊加并不是簡(jiǎn)單的數(shù)字之和。下面通過一個(gè)案例來具體說明,如例1所示。

例1 examplel1.html

復(fù)合選擇器權(quán)重的疊加.inner{text-decoration:line-through;}/*類選擇器定義刪除線,權(quán)重為10*/div?div?div?div?div?div?div?div?div?div?div{text-decoration:underline;}/*后代選擇器定義下畫線,權(quán)重為11個(gè)1的疊加*/?
??
?????文本的樣式
??

例1共使用了11對(duì)

標(biāo)簽,它們層層嵌套。第15行代碼我們對(duì)最里層的
定義類名“inner”。第7、8行代碼,使用類選擇器和后代選擇器分別定義最里層div的樣式。此時(shí)瀏覽器中文本的樣式到底如何顯示呢?如果僅僅將基礎(chǔ)選擇器的權(quán)重相加,后代選擇器(包含11層div)的權(quán)重為11,大于類選擇器“.inner”的權(quán)重10,文本將添加下畫線。

運(yùn)行例1,效果如下所示。

1670579654196_復(fù)合選擇器.png

在上圖中,文本并沒有像預(yù)期的那樣添加下畫線,而顯示了類選擇器“.inner”定義的刪除線??梢?,無論在外層添加多少個(gè)標(biāo)簽,復(fù)合選擇器的權(quán)重?zé)o論為多少個(gè)

標(biāo)簽選擇器的疊加,其權(quán)重都不會(huì)高于類選擇器。同理,復(fù)合選擇器的權(quán)重?zé)o論為多少個(gè)類選擇器和標(biāo)簽選擇器的疊加,其權(quán)重都不會(huì)高于i選擇器。

相關(guān)內(nèi)容

搶先一步 鴻蒙(HarmonyOS)應(yīng)用開發(fā)者高級(jí)認(rèn)證 免費(fèi)考! 適合人群計(jì)算機(jī)相關(guān)專業(yè)在校生(技師、中職、高職、本科、研究生)對(duì)鴻蒙(HarmonyOS)有興趣的非計(jì)算機(jī)相關(guān)專業(yè)在校生目前正在從事移動(dòng)應(yīng)用的開發(fā)者目前正在從事計(jì)算機(jī)行業(yè)相關(guān)的人計(jì)算機(jī)專業(yè)高校老師所有對(duì)鴻蒙(HarmonyOS)有興趣的人 培訓(xùn)方案掌握鴻蒙的核心概念和端云一體化開發(fā)、... 什么是Java的多態(tài)性(polymorphism)?它有哪些不同的形式? 多態(tài)性是Java面向?qū)ο缶幊痰囊粋€(gè)重要概念,它允許不同的對(duì)象以一致的方式響應(yīng)同一個(gè)方法調(diào)用,具體表現(xiàn)為對(duì)象在運(yùn)行時(shí)可以表現(xiàn)出多個(gè)不同的形態(tài)。多態(tài)性主要有兩種不同的形式:編譯時(shí)多態(tài)性(靜態(tài)多態(tài)性)和運(yùn)行時(shí)多態(tài)性(動(dòng)態(tài)多態(tài)性)。1. 編譯時(shí)多態(tài)性(靜態(tài)多態(tài)性):   ... 如何學(xué)習(xí)和搭建Hadoop開發(fā)環(huán)境? Hadoop是大數(shù)據(jù)處理領(lǐng)域的重要平臺(tái),能夠處理和分析大量數(shù)據(jù)。為了有效地利用Hadoop,我們需要學(xué)習(xí)其基礎(chǔ)知識(shí),并正確搭建開發(fā)環(huán)境。下面是詳細(xì)的學(xué)習(xí)和搭建指南。一、學(xué)習(xí)Hadoop基礎(chǔ)掌握基礎(chǔ)概念和原理Hadoop主要由HDFS和MapReduce兩部分組成。HDFS是分布式文件系統(tǒng),Ma... UI 設(shè)計(jì)學(xué)習(xí)如何進(jìn)階成為高手 我總結(jié)了六種方法,幫助你走出舒適區(qū),提高技能,成長(zhǎng)為自信且經(jīng)驗(yàn)豐富的UI設(shè)計(jì)高手一位經(jīng)驗(yàn)豐富的 UI 設(shè)計(jì)師,往往十分看中應(yīng)用程序界面的吸引力和視覺刺激,確保滿足用戶期望和需求。但是,如果你已經(jīng)在 UI 設(shè)計(jì)圈摸爬滾打多年,仍然沒有出色的作品,那你極有可能是因?yàn)橄萑肓艘粋€(gè)舒適圈,UI技能一直原... 在Java中Executor和Executors的區(qū)別? 在Java中,Executor和Executors都與線程池和并發(fā)執(zhí)行有關(guān),但它們是不同的概念和類。1.ExecutorExecutor是一個(gè)接口,位于java.util.concurrent包中,用于表示一個(gè)執(zhí)行任務(wù)的執(zhí)行器。它只定義了一個(gè)方法:void execute(Runnable c... String類型的常見命令有哪些? String類型,也就是字符串類型,是Redis中最簡(jiǎn)單的存儲(chǔ)類型。其value是字符串,不過根據(jù)字符串的格式不同,又可以分為3類:string是普通字符串,int整數(shù)類型,可以做自增、自減操作,float浮點(diǎn)類型,可以做自增、自減操作。String的常見命令有:SET:添加或者修改已經(jīng)存在的...