首頁 >web前端 >css教學 >::before有什麼作用? ::before與:before的差別是什麼?

::before有什麼作用? ::before與:before的差別是什麼?

青灯夜游
青灯夜游原創
2018-11-12 10:31:1148502瀏覽

::before是什麼?有什麼作用?這篇文章就給大家::before有什麼用,讓大家了解::before的簡單使用,以及::before與:before的異同點。有一定的參考價值,有需要的朋友可以參考一下,希望對你們有幫助。

一、::before是什麼?有什麼作用?

在css中,::before 是一個偽類別元素,代表產生的內容元素,表示對應元素的可抽象樣式的第一個子元素,即:所選元素的第一個子元素。 【相關影片教學建議:css教學

利用::before可以把需插入的內容插入到元素的其他內容之前,並且預設內嵌顯示。 ::before需要使用content屬性來指定內容的值。例:

/* 在链接之前添加一颗心 */
a::before {
  content: "♥";
}

我們來看一個簡單的範例:

假設你有一個帶有一些文字的blockquote。你可以使用::before在實際文字之前插入內容,例如:一些花俏的引號。引號將顯示在頁面上,但不會加入DOM中的blockquote。

< blockquote >
    你目前的情况并不能确定你可以去哪里; 他们只是决定你从哪里开始。- Nido Qubein
</ blockquote >

以下程式碼片段將使用區塊引用添加幾個花哨的引號::before。引號將在引用文本之前的blockquote中添加,並與其內聯。

blockquote :: before {     
  content:“\ 201C” ;    / *样式引用* /     
  color:deepPink;    
  font-size: 3em;    
  position: relative;    
  top: 20px;
}

content引用是透過轉義其在屬性內定義的Unicode值。這就是通常透過CSS表示和添加字形的方式。

我們來看看運行效果:

::before有什麼作用? ::before與:before的差別是什麼?

由於使用偽元素插入的內容未插入DOM內,因此通常無法使用瀏覽器的開發者工具查看和檢查插入的內容。但是,Chrome 32 和Firebug for Firefox允許你查看偽元素在DOM中的位置,透過選擇它,你可以在CSS面板中查看與其相關聯的樣式。在Chrome的開發工具中檢查上述示範會顯示以下結果:


::before有什麼作用? ::before與:before的差別是什麼?

#可以看出,新增有::before的內容與blockquote內的其他內容內聯並位於其之前。

由於::before內容是在元素內的其他內容之前插入的,這也意味著偽元素將堆疊在來源樹中的其他元素之後。

偽元素可用於插入幾乎任何類型的內容,包括字元(如上所述),文字字串和圖像。例如,以下是::before具有有效內容的所有有效聲明:

.element :: before {   
  content:url(path / to / image.png); / *图像,例如,图标* /
}
.element :: before {    
  content:“注意:” ; / *一个字符串* /
}
.element :: before {   
  content:“\ 201C” ; / *也算作一个字符串。转义Unicode会将其渲染为字符* /
}

註:使用偽元素插入的圖像無法調整大小,它們會按原樣插入,因此你必須在使用前調整圖像大小。

二、::before與:before的異同點

相同點:

1、偽類別對象,用來設定物件前的內容

2、::before和:before寫法是等效的

不同點:

:befor是Css2的寫法,::before是Css3的寫法

:before的相容性要比::before好,不過在H5開發中建議使用::before比較好

說明:

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

2、偽類元素是css渲染層加入的,不能透過js來操作

3、偽類物件特效通常透過:hover偽類樣式來啟動

.test:hover::before{
    /* 这时animation和transition才生效 */
}

總結:以上就是本篇文章的全部內容,希望對大家的學習有所幫助。

以上是::before有什麼作用? ::before與:before的差別是什麼?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn