css中偽類別和偽物件(偽元素)差異是什麼
偽類是用於為某些選擇器添加特殊效果的;偽元素是用於將特殊的效果添加到某些選擇器的。偽類的效果可以透過添加實際的類別來實現;偽物件的效果可以透過添加實際的元素來實現。簡單來說,它們的本質區別為是否抽象創造了新元素。
本教學操作環境:windows7系統、CSS3版、Dell G3電腦。
其中偽類別和偽元素(偽物件)的根本差異在於:它們是否創造了新的元素。
偽元素/偽物件:不存在在DOM文件中,是虛擬的元素,是建立新元素。代表某個元素的子元素,這個子元素雖然在邏輯上存在,但卻不實際存在於文檔樹中。
偽物件選擇符
#Properties 屬性 |
CSS Version 版本 |
Inherit From Parent 繼承性 |
Description 簡介 |
---|---|---|---|
CSS3/CSS1 | #無 | CSS2/CSS1 E:first-letter/E::first-letter 偽物件選擇符,設定物件內的第一個字元的樣式。 | |
#CSS3/CSS1 | 無 | ##CS3/CSS1 偽物件選擇符E:first-line/E::first-line,設定物件內的第一行的樣式。 | |
CSS3/CSS2 | CSS3/CSS3 偽物件選擇子E :before/E::before,設定在物件前(依據物件樹的邏輯結構)所發生的內容。用來和content屬性一起使用 | ||
CSS3/CSS2 | 沒有 | CSS3 /CSS2 偽物件選擇符E:after/E::after,設定在物件後面(依據物件樹的邏輯結構)所發生的內容。用來和content屬性一起使用 | |
CSS3 | 無 | CSS3 偽物件選擇子E: :selection,設定物件被選擇時的顏色。 |
#Properties 屬性 |
CSS Version 版本 |
Inherit From Parent 繼承性 |
Description 簡介 |
---|---|---|---|
CSS1 | 無 | CSS1 偽類選擇子E:link ,設定超連結a在未被存取前的樣式。 | |
CSS1 | #無 | CSS1 偽類別選擇子E:visited,設定超連結a在其連結地址已被存取過時的樣式。 | |
CSS2 | #無 | CSS2/CSS1 偽類別選擇符E:hover,設定元素在其滑鼠懸停時的樣式。 | |
CSS2/CSS1 | #無 | CSS2/CSS1 偽類別選擇符E:active,設定元素在被使用者啟動(在滑鼠點擊與釋放之間發生的事件)時的樣式。 | |
CSS2/CSS1 | 無 | CSS2/CSS1 偽類別選擇符E:focus,設定元素在成為輸入焦點(該元素的onfocus事件發生)時的樣式。 | |
CSS2 | #無 | CSS2 偽類別選擇子E:lang() 符合使用特殊語言的E元素。 | |
CSS3 | #無 | CSS3 偽類別選擇子E:not() 符合不含s選擇符的元素E。 | |
CSS3 | 無 | CSS3 偽類別選擇子E:root,符合E元素在文件的根元素。 | |
CSS2 | #CSS2 偽類別選擇子E:first-child 符合父元素的第一個子元素E。 | ||
CSS3 | #無 | CSS3 偽類別選擇子E:last-child 符合父元素的最後一個子元素E。 | |
CSS3 | #無 | CSS3 為例選擇符號E:only-child 符合父元素僅有的一個子元素E。 | |
CSS3 | 無 | CSS3 偽類別選擇子E:nth-child (n) 符合父元素的第n個子元素E。 | |
CSS3 | 無 | ##CSS3 偽類別選擇子E:nth -last-child(n) 符合父元素的倒數第n個子元素E。 | |
CSS2 | 無 | CSS3 偽類別選擇子E:first-of- type 符合同類型中的第一個同級兄弟元素E。 | |
CSS3 | #無 | CSS3 偽類別選擇子E:last-of- type 符合同類型中的最後一個同級兄弟元素E。 | |
CSS3 | 無 | CSS3 偽類別選擇子E:only-of- type,匹配同類型中的唯一的一個同級兄弟元素E。 | |
CSS3 | 無 | ##CSS3 偽類別選擇子E:nth -of-type(n),匹配同類型中的第n個同級兄弟元素E。E:nth-last-of-type(n) | |
無 | CSS3 偽類別選擇子E :nth-last-of-type(n) 符合同類型中的倒數第n個同級兄弟元素E。 | E:empty | |
#無 | CSS3 偽類別選擇子E:empty 符合沒有任何子元素(包括text節點)的元素E。 | E:checked | |
#無 | CSS3 偽類別選擇符E:checked 符合使用者介面上處於選取狀態的元素E。 (用於input type為radio與checkbox 的form元素) | E:enabled | |
#無 | #CSS3 偽類別選擇符E:enabled 匹配使用者介面上處於可用狀態的元素E。 | E:disabled | |
#無 | CSS3 偽類別選擇子E:disabled 符合使用者介面上處於停用狀態的元素E。 | E:target | |
#無 | CSS3 偽類別選擇子E:target 符合相關URL指向的E元素。 | @page:first | |
#無 | CSS2 偽類別選擇符@page:first 設定頁面容器第一頁使用的樣式。只用於@page規則 | @page:left | |
無 | ##CSS2 偽類別選擇符@page: left 置頁面容器位於裝訂線左邊的所有頁面所使用的樣式。僅用於@page規則 | @page:right | |
無 | CSS2 為物件選擇符@page: right 設定頁面容器位於裝訂線右邊的所有頁面所使用的樣式。只用於@page規則 |
再看看W3C中對於二者應用的描述:偽類:用於向某些選擇器添加特殊的效果 舉個栗子: <div> <p>a</p> <p>b c</p> </div> 登入後複製 如果我們想要第一個p標籤字體顏色變紅怎麼做呢使用偽類就會很簡單: p:first-child { color: red; } 登入後複製 登入後複製 但是如果不用偽類我們怎麼做呢?這時我們就需要為第一個p標籤添加一個類別class <div> <p class="first-child">a</p> <p>b c</p> </div> 登入後複製 p:first-child { color: red; } 登入後複製 登入後複製 可以實現同樣的效果,但是需要多寫一個類別 如果使用偽元素該如何實現上述操作呢? p::first-letter { color: red; } 登入後複製 如果不用偽元素我們怎麼做呢? <div> <p><span>a</span></p> <p>b c</p> </div> 登入後複製 p span { color: red; } 登入後複製 可以看出二者差異了, 偽類別的效果可以透過加入實際的類別來實現 偽元素的效果可以透過加入實際的元素來實現 所以它們的本質差異就是是否抽象創造了新元素 注意: #偽類別只能使用“ 而偽元素既可以使用“ 因為偽類別是類似新增類別所以可以是多個,而偽元素在一個選擇器中只能出現一次,只能出現在結尾 相關問題 #:after/::after和:before/::before的異同 相同點: 都可以用來表示偽類別對象,用來設定物件前的內容 :before和::before寫法是等效的; :after和::after寫法是等效的 不同點: :before/:after是Css2的寫法,::before/::after是Css3的寫法 :before/:after 的兼容性要比::before/::after好, #不過在H5開發中建議使用::before/::after比較好 注意: #偽物件要配合content屬性一起使用 偽物件不會出現在DOM中,所以不能透過js來操作,只是在CSS 渲染層加入 偽物件的特效通常要使用:hover偽類樣式來啟動 eg:當滑鼠移在span上時,span前插入”duang” <style> span{ background: yellow; } span:hover::before{ content:"duang"; } </style> <span>222</span> 登入後複製 (學習視頻分享:css視頻教程) |
以上是css中偽類別和偽物件(偽元素)差異是什麼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

Video Face Swap
使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

SublimeText3 Mac版
神級程式碼編輯軟體(SublimeText3)

在 Vue.js 中使用 Bootstrap 分為五個步驟:安裝 Bootstrap。在 main.js 中導入 Bootstrap。直接在模板中使用 Bootstrap 組件。可選:自定義樣式。可選:使用插件。

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML定義網頁結構,CSS負責樣式和佈局,JavaScript賦予動態交互。三者在網頁開發中各司其職,共同構建豐富多彩的網站。

創建 Bootstrap 分割線有兩種方法:使用 標籤,可創建水平分割線。使用 CSS border 屬性,可創建自定義樣式的分割線。

在 Bootstrap 中插入圖片有以下幾種方法:直接插入圖片,使用 HTML 的 img 標籤。使用 Bootstrap 圖像組件,可以提供響應式圖片和更多樣式。設置圖片大小,使用 img-fluid 類可以使圖片自適應。設置邊框,使用 img-bordered 類。設置圓角,使用 img-rounded 類。設置陰影,使用 shadow 類。調整圖片大小和位置,使用 CSS 樣式。使用背景圖片,使用 background-image CSS 屬性。

要設置 Bootstrap 框架,需要按照以下步驟:1. 通過 CDN 引用 Bootstrap 文件;2. 下載文件並將其託管在自己的服務器上;3. 在 HTML 中包含 Bootstrap 文件;4. 根據需要編譯 Sass/Less;5. 導入定製文件(可選)。設置完成後,即可使用 Bootstrap 的網格系統、組件和样式創建響應式網站和應用程序。

要調整 Bootstrap 中元素大小,可以使用尺寸類,具體包括:調整寬度:.col-、.w-、.mw-調整高度:.h-、.min-h-、.max-h-

如何使用 Bootstrap 按鈕?引入 Bootstrap CSS創建按鈕元素並添加 Bootstrap 按鈕類添加按鈕文本
