溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

如何全面解析CSS優(yōu)先級(jí)規(guī)則

發(fā)布時(shí)間:2021-11-18 09:23:45 來(lái)源:億速云 閱讀:111 作者:柒染 欄目:web開(kāi)發(fā)

這篇文章將為大家詳細(xì)講解有關(guān)如何全面解析CSS優(yōu)先級(jí)規(guī)則,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

和大家重點(diǎn)討論一下CSS優(yōu)先級(jí),既然樣式有優(yōu)先級(jí),那么就會(huì)有一個(gè)規(guī)則來(lái)約定這個(gè)優(yōu)先級(jí),而這個(gè)“規(guī)則”就是本次所需要講的重點(diǎn)。

關(guān)于CSS優(yōu)先級(jí)的詳細(xì)解說(shuō)

在講CSS優(yōu)先級(jí)之前,我們得要了解什么是CSS,CSS是用來(lái)做什么的。簡(jiǎn)單說(shuō)來(lái),CSS是層疊樣式表(CascadingStyleSheets)的簡(jiǎn)稱。它的規(guī)范代表了互聯(lián)網(wǎng)歷史上一個(gè)獨(dú)特的發(fā)展階段?,F(xiàn)在對(duì)于從事網(wǎng)頁(yè)制作的朋友來(lái)說(shuō),應(yīng)該很少?zèng)]有聽(tīng)說(shuō)過(guò)CSS了,因?yàn)樵谥谱骶W(wǎng)頁(yè)過(guò)程中我們經(jīng)常需要用到。我們能通過(guò)CSS為文檔設(shè)置豐富且易于修改的外觀,以減輕網(wǎng)頁(yè)制作者的工作負(fù)擔(dān),從而減輕制作及后期維護(hù)的代價(jià)。

其實(shí)現(xiàn)在還來(lái)講CSS是什么,CSS有什么作用完全是多余的,相信從事網(wǎng)頁(yè)制作的朋友都已經(jīng)或多或少的接觸過(guò)了。言歸正傳,開(kāi)始進(jìn)入今天的話題。

一、什么是CSS優(yōu)先級(jí)?

所謂CSS優(yōu)先級(jí),即是指CSS樣式在瀏覽器中被解析的先后順序。

二、CSS優(yōu)先級(jí)規(guī)則

既然樣式有優(yōu)先級(jí),那么就會(huì)有一個(gè)規(guī)則來(lái)約定這個(gè)優(yōu)先級(jí),而這個(gè)“規(guī)則”就是本次所需要講的重點(diǎn)。

樣式表中的特殊性描述了不同規(guī)則的相對(duì)權(quán)重,它的基本規(guī)則是:

1、統(tǒng)計(jì)選擇符中的ID屬性個(gè)數(shù)。

2、統(tǒng)計(jì)選擇符中的CLASS屬性個(gè)數(shù)。

3、統(tǒng)計(jì)選擇符中的HTML標(biāo)記名個(gè)數(shù)。

***,按正確的順序?qū)懗鋈齻€(gè)數(shù)字,不要加空格或逗號(hào),得到一個(gè)三位數(shù)(css2.1是用4位數(shù)表示)。(注意,你需要把數(shù)字轉(zhuǎn)換成一個(gè)以三個(gè)數(shù)字結(jié)尾的更大的數(shù))。相應(yīng)于選擇符的最終數(shù)字列表可以很容易確定較高數(shù)字特性凌駕于較低數(shù)字的。

例如:

1、每個(gè)ID選擇符(#someid),加0,1,0,0。

2、每個(gè)class選擇符(.someclass)、每個(gè)屬性選擇符(形如[attr=value]等)、每個(gè)偽類(形如:hover等)加0,0,1,0。

3、每個(gè)元素或偽元素(:firstchild)等,加0,0,0,1。

4、其它選擇符包括全局選擇符*,加0,0,0,0。相當(dāng)于沒(méi)加,不過(guò)這也是一種specificity,后面會(huì)解釋。

三、特性分類的選擇符列表

以下是一個(gè)按特性分類的選擇符的列表:

如何全面解析CSS優(yōu)先級(jí)規(guī)則

單從上面這個(gè)表來(lái)看,貌似不大好理解,下面再給出一張表:

如何全面解析CSS優(yōu)先級(jí)規(guī)則

通過(guò)上面,就可以很簡(jiǎn)單的看出,HTML標(biāo)記的權(quán)重是1,CLASS的權(quán)重是10,ID的權(quán)重是100,繼承的權(quán)重為0(后面會(huì)講到)。

按這些規(guī)則將數(shù)字符串逐位相加,就得到最終的權(quán)重,然后在比較取舍時(shí)按照從左到右的順序逐位比較。

優(yōu)先級(jí)問(wèn)題其實(shí)就是一個(gè)沖突解決的問(wèn)題,當(dāng)同一個(gè)元素(內(nèi)容)被CSS選擇符選中時(shí),就要按照優(yōu)先級(jí)取舍不同的CSS規(guī)則,這其中涉及到的問(wèn)題其實(shí)很多。

關(guān)于如何全面解析CSS優(yōu)先級(jí)規(guī)則就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺(jué)得文章不錯(cuò),可以把它分享出去讓更多的人看到。

向AI問(wèn)一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

css
AI