偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

偽類與偽元素是怎么回事兒

開發(fā) 前端
想要了解偽類與偽元素,我們不得不提到 CSS 選擇器,CSS 選擇器是元素和其他部分組合起來,告訴瀏覽器哪個(gè) HTML 元素應(yīng)當(dāng)是被選為應(yīng)用規(guī)則中的 CSS 屬性值的方式。

[[414292]]

本文轉(zhuǎn)載自微信公眾號(hào)「三分鐘學(xué)前端」,作者sisterAn。轉(zhuǎn)載本文請(qǐng)聯(lián)系三分鐘學(xué)前端公眾號(hào)。

CSS 選擇器

想要了解偽類與偽元素,我們不得不提到 CSS 選擇器,CSS 選擇器是元素和其他部分組合起來,告訴瀏覽器哪個(gè) HTML 元素應(yīng)當(dāng)是被選為應(yīng)用規(guī)則中的 CSS 屬性值的方式

選擇器的種類有:

  • 類型、類和ID選擇器
  • 標(biāo)簽屬性選擇器
  • 運(yùn)算符
  • 偽類與偽元素

類型、類和ID選擇器

  1. h1 { } /* 類型選擇器 */ 
  2. .box { } /* 類選擇器 */ 
  3. #unique { } /* ID選擇器 */ 

標(biāo)簽屬性選擇器

這組選擇器根據(jù)一個(gè)元素上的某個(gè)標(biāo)簽屬性是否存在來選擇:

  1. a[title] { } 

或者根據(jù)標(biāo)簽屬性是否是特定值來選擇:

  1. a[href="https://example.com"] { } 

運(yùn)算符

這種選擇器可以將其他選擇器組合起來,更復(fù)雜的選擇元素。下面的示例就是利用運(yùn)算符(>)選擇了 元素的初代子元素

  1. article > p { } 

偽類與偽元素

最后一組就是偽類與偽元素,這一類選擇器的數(shù)量眾多,通常用于很明確的目的

偽類與偽元素

什么是偽類?什么是偽元素?

  • 偽類:用于選擇處于 特定狀態(tài) 的元素,比如鼠標(biāo)懸浮狀態(tài)( :hover )。它們表現(xiàn)得會(huì)像是你向你的文檔的某個(gè)部分應(yīng)用了一個(gè)類一樣,幫你在你的標(biāo)記文本中減少多余的類,讓你的代碼更靈活、更易于維護(hù)。
  • 偽元素:以類似方式表現(xiàn),不過表現(xiàn)得是像你往標(biāo)記文本中加入全新的HTML元素一樣,產(chǎn)生的效果是把不存在的元素硬選出來

偽類與偽元素的區(qū)別

表現(xiàn)方式區(qū)別:

偽類表現(xiàn)的是某種狀態(tài)被選擇出來,例如 :hover 、 :checked ,而偽元素表現(xiàn)的是選擇元素的某個(gè)部分,使這部分看起來像一個(gè)獨(dú)立的元素,其實(shí)并不是,例如 ::before 、 ::after

抽象的說,偽類就是選擇元素某狀態(tài),偽元素就是創(chuàng)建一個(gè)HTML元素

符號(hào)區(qū)別

偽類使用單冒號(hào) : ,偽元素開頭為雙冒號(hào) :: ,單需要注意的是 CSS3 之前并沒有定義偽元素,都統(tǒng)稱為偽類,所以目前絕大多數(shù)的瀏覽器都同時(shí)支持使用這兩種方式來表示偽元素

常見的偽類與偽元素

偽類:

偽元素:

::before 與 ::after

接下來我們說說最常用、最經(jīng)典的 ::before 和 ::after 偽元素, ::before 表示在元素內(nèi)容之前插入一個(gè)虛擬的元素, ::after 則表示在元素內(nèi)容之后插入,并且 ::before 和 ::after 中支持所有的 CSS 屬性。

但需要注意的是這兩個(gè)偽元素所在的 CSS 規(guī)則必須指定 content 屬性才會(huì)生效

content 屬性

content 可取string、attr()、url()/uri():

string

  1. <p>三分鐘學(xué)前端</p> 
  2. <style> 
  3.   p::before{ 
  4.     content: "❤️"
  5.     color: red; 
  6.   } 
  7.   p::after
  8.     content: "❤️"
  9.     color: red; 
  10.   } 
  11. </style> 

[[414293]]

attr()

  1. <a href="https://github.com/Advanced-Frontend/Daily-Interview-Question">❤️三分鐘學(xué)前端❤️</a> 
  2. <style> 
  3.   a::after { 
  4.     content: ' → ' attr(href); /* 在 href 前顯示一個(gè)箭頭 */ 
  5.   } 
  6. </style> 

url()/uri()

  1. <p>❤️三分鐘學(xué)前端❤️</p> 
  2. <style> 
  3.   p::after { 
  4.     content: url("http://resource.muyiy.cn/image/20210729234502.jpeg"); 
  5.   } 
  6. </style> 

[[414294]]

 

這兩個(gè)偽元素常用于一些修飾性元素,以純 CSS 代碼添加進(jìn)去,就能很好地保持 HTML 代碼中的語(yǔ)義,既完成了顯示效果,又不會(huì)讓 DOM 中出現(xiàn)很多無語(yǔ)義的空元素

原文鏈接:https://github.com/Advanced-Frontend/Daily-Interview-Question

 

責(zé)任編輯:武曉燕 來源: 三分鐘學(xué)前端
相關(guān)推薦

2017-11-24 11:10:38

區(qū)塊鏈礦工分叉

2018-05-08 08:46:47

Linux內(nèi)存釋放

2011-05-23 14:10:00

2020-08-18 08:08:59

CSS偽元素偽類

2021-07-07 05:37:57

郵件安全網(wǎng)絡(luò)攻擊數(shù)據(jù)泄露

2020-06-30 08:12:32

VMwareKVMDocker

2023-03-29 08:24:30

2022-10-19 12:00:32

CSS 偽類偽元素

2020-02-18 11:19:36

物聯(lián)網(wǎng)病毒物聯(lián)網(wǎng)IOT

2016-10-19 14:54:46

css選擇器css3css

2015-04-23 09:34:51

Windows開源

2021-06-04 11:10:04

JavaScript開發(fā)代碼

2023-05-31 16:40:01

2018-01-25 16:07:41

匿名函數(shù)自執(zhí)行

2010-09-06 12:32:10

CSS偽元素

2017-08-08 15:35:37

前端CSS偽元素

2023-03-05 15:41:58

MySQL日志暴漲

2013-04-18 09:56:05

2021-05-11 11:51:15

飛機(jī)Wi-Fi通信

2016-11-22 19:54:56

點(diǎn)擊率預(yù)估推薦算法廣告
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)