溫馨提示×

溫馨提示×

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

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

css中偽類和偽元素有哪些區(qū)別

發(fā)布時間:2020-09-10 15:33:08 來源:億速云 閱讀:165 作者:小新 欄目:web開發(fā)

這篇文章將為大家詳細講解有關(guān)css中偽類和偽元素有哪些區(qū)別,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

偽類用于選擇DOM樹之外的信息,或是不能用簡單選擇器進行表示的信息。前者包含那些匹配指定狀態(tài)的元素,比如:visited,:active;后者包含那些滿足一定邏輯條件的DOM樹中的元素,比如:first-child:first-of-type,:target。

(相當(dāng)于一個特殊的class選擇器,用來添加一些特殊效果)

偽元素為DOM樹沒有定義的虛擬元素。不同于其他選擇器,它不以元素為最小選擇單元,它選擇的是元素指定內(nèi)容。比如::before表示選擇元素內(nèi)容的之前內(nèi)容,也就是"";::selection表示選擇元素被選中的內(nèi)容。

(相當(dāng)于一個特殊的元素(p、span),可以用來存放一些特殊樣式或者內(nèi)容)

在CSS3中,偽類與偽元素在語法上也有所區(qū)別,偽元素修改為以::開頭。但因為歷史原因,瀏覽器對以:開頭的偽元素也繼續(xù)支持,但建議規(guī)范書寫為::開頭。

  • 偽類

SelectorMeaningCSS
:active選擇正在被激活的元素1
:hover選擇被鼠標懸浮著元素1
:link選擇未被訪問的元素1
:visited選擇已被訪問的元素1
:first-child選擇滿足是其父元素的第一個子元素的元素2
:lang選擇帶有指定 lang 屬性的元素2
:focus選擇擁有鍵盤輸入焦點的元素2
:enable選擇每個已啟動的元素3
:disable選擇每個已禁止的元素3
:checked選擇每個被選中的元素3
:target選擇當(dāng)前的錨點元素3
:first-of-type選擇滿足是其父元素的第一個某類型子元素的元素3
:last-of-type選擇滿足是其父元素的最后一個某類型子元素的元素3
:only-of-type選擇滿足是其父元素的唯一一個某類型子元素的元素3
:nth-of-type(n)選擇滿足是其父元素的第n個某類型子元素的元素3
:nth-last-of-type(n)選擇滿足是其父元素的倒數(shù)第n個某類型的元素3
:only-child選擇滿足是其父元素的唯一一個子元素的元素3
:last-child選擇滿足是其父元素的最后一個元素的元素3
:nth-child(n)選擇滿足是其父元素的第n個子元素的元素3
:nth-last-child(n)選擇滿足是其父元素的倒數(shù)第n個子元素的元素3
:empty選擇滿足沒有子元素的元素3
:in-range選擇滿足值在指定范圍內(nèi)的元素3
:out-of-range選擇值不在指定范圍內(nèi)的元素3
:invalid選擇滿足值為無效值的元素3
:valid選擇滿足值為有效值的元素3
:not(selector)選擇不滿足selector的元素3
:optional選擇為可選項的表單元素,即沒有“required”屬性3
:read-only選擇有"readonly"的表單元素3
:read-write選擇沒有"readonly"的表單元素3
:root選擇根元素3
  • 偽元素

    SelectorMeaningCSS
    ::first-letter選擇指定元素的第一個單詞1
    ::first-line選擇指定元素的第一行1
    ::after在指定元素的內(nèi)容前面插入內(nèi)容2
    ::before在指定元素的內(nèi)容后面插入內(nèi)容2
    ::selection選擇指定元素中被用戶選中的內(nèi)容3

:before和::before的區(qū)別

  1. 二者寫法是等效的,都表示偽元素。

  2. :before是CSS2的寫法,::before是CSS3的寫法。

  3. :before的兼容性比::before兼容性好,但是H5開發(fā)中建議使用::before

注意:

  1. 偽元素要配合content屬性一起使用

  2. 偽元素不會出現(xiàn)在DOM中,所以不能通過js來操作,僅僅是在 CSS 渲染層加入

  3. 偽元素的特效通常要使用:hover偽類樣式來激活

.test:hover::before { /* 這時animation和transition才生效 */ }

關(guān)于css中偽類和偽元素有哪些區(qū)別就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

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

AI