Heim Web-Frontend HTML-Tutorial CSS before和after伪类元素应用实例及分析

CSS before和after伪类元素应用实例及分析

Jun 01, 2016 am 09:53 AM
after before 伪类

在分析before和after伪元素之前,我们先看一个实例, 这个实例使用了css伪类元素affter制作了一个自定义的input check样式。

实例如下:

<code class="css">


<title>CSS input checkbox自定义样式</title>
<style type="text/css">
.compare_button .checkboxcss {
    cursor: pointer;
    position: absolute;
    width: 15px;
    height: 15px;
    top: 0;
    left: 0;
    background: #f7f7f7;
    border: 2px solid #f5b34f;
    border-radius: 5px;
}
.compare_button {
    position: relative;
}
.compare_button .checkboxcss:after {
    opacity: 0;
    content: '';
    position: absolute;
    width: 7px;
    height: 3px;
    background: transparent;
    top: 3px;
    left: 3px;
    border: 3px solid #1e8cc5;
    border-top: none;
    border-right: none;
    -webkit-transform: rotate(-45deg);
    -moz-transform: rotate(-45deg);
    -o-transform: rotate(-45deg);
    -ms-transform: rotate(-45deg);
    transform: rotate(-45deg);
}
.compare_button input[type=checkbox]:checked + label:after {
    opacity: 1;
}
</style>


<div class="compare_button">
        <input type="checkbox" id="compare_39680" class="checkbox-input">
        <label class="checkboxcss" for="compare_39680"></label>
        <span>compare text</span>
    </div>

</code>
Nach dem Login kopieren

效果图:

CSS before和after伪类元素应用实例及分析

 

下面我们对CSS before和after伪类元素的用法进行描述

一、伪元素基本用法

在CSS选择器中加上相应伪类选择符就可以了,像这样:#example: before或者#example: after,这里是使用ID选择器,比如下面的CSS代码:

<code class="css">#example:before {
  content: "\"";
}
#example:after {
  content: "\"";
}</code>
Nach dem Login kopieren

它的效果就是为example标签前后加上双引号。

      和伪类的选择符很像,但是有一点小区别,就是伪类选择符实际上是用两个冒号,::before的形式,以和伪类区别开,但是只用一个冒号浏览器也是可以识别的,在CSS3中规定是一个冒号就可以了。

      如果没有绑定标签,像这样::before{ content:”=”;} 这样的伪元素是没有意义的,代码会在DOM里的每个元素的内容之前插入散列符号。即使你删除了

标签和它的所有内容,你仍会在页面上看见两个散列符号:一个在里,另一个在标签里。

      那么可不可以给伪元素再添加伪元素呢?比如下面这个代码:

<code class="css">#example:after:after{
    content: "after";
}</code>
Nach dem Login kopieren

在浏览器中刷新,测试一下会发现什么也没有显示,也就是说再给伪元素添加伪元素目前很多浏览器上是无效的,浏览器忽略掉该定义,只能识别一层伪元素,但是既然可以伪元素添加伪元素,可以期待再为伪元素添加伪元素,其表现力是很强的。

 

二、伪元素属性和样式

1.content属性

每个伪元素必须要有content属性,否则的话浏览器不能识别,你可以为content属性添加空引用作为它的值(即:content:“”)。

你也可以为content包含一个指向一个图像的URL,就像在css里包含一个背景图像一样:

<code class="css">p:before {

  content: url(image.jpg);
}</code>
Nach dem Login kopieren

也可以包含一个Data URI代替图像引用,就像使用css背景一样。

你还可以选择ATRR(X)中的函数的形式。“把X属性的值以字符串的形式返回”,比如:

<code class="css">a:after {
  content: attr(href);
}</code>
Nach dem Login kopieren

attr()函数的功能是把得到特定属性的值并把它作为插入的文本成为一个伪元素。

上面的代码会导致页面上的每一个元素的href值立即被放置在每个各自的元素的后面。在文档被打印时,它可以用作一个包含所有URl的打印样式表。

2.标签属性

伪元素也是元素,所以你可以为它添加大部分其他元素具有的属性,比如定位属性,字体属性,背景属性和盒模型的属性等,另外由于伪元素默认是内联元素,所以如果要使得盒模型中的height等属性有效的话,必须要把它转化为块元素,具体就是设置其display属性为block,或者设置为float等。如下:

<code class="css">#example:after{
    position: absolute;
    display: block;
    left: 20px;
    top: 20px;
    content: "\"";
    width: 20px;
    height: 20px;
    background: #6F3;
}</code>
Nach dem Login kopieren

既然伪元素可以定义position等属性,那么before和after的约束就很有限了,before和after的区别只能是在没有特殊定义伪元素的位置等信息的时候的默认行为不一致,before出现在相对绑定的元素之前,而after出现在相对绑定的元素位置之后。

另外既然可以为伪元素定义盒子模型的属性,就不得不说,伪元素默认为其目标元素的子元素,比如#example:after,伪元素after的父元素就是#example选择符对应的元素,它具有一般子元素盒模型的特性,即为他定义的height和width等属性规则为影响目标元素的规则。

 

三、伪元素的兼容性

基本可以放心的使用伪元素,因为它有很好的兼容性,可以不用加浏览器前缀而很好的使用它。

支持:before 和 :after 伪元素的浏览器有:

  • Chrome 2+,
  • Firefox 3.5+ (3.0 had partial support),
  • Safari 1.3+,
  • Opera 9.2+,
  • IE8+ (with some minor bugs),
  • 几乎所有的移动浏览器。

但是IE6和IE7上并不支持,如果不是很在意他们的用户数量的话,基本可以很自由的使用啦。

 

四、伪元素的作用

     这里借用Thoriq Firdaus的几个例子简单说一下伪元素的用法。另外伪元素既然是伪元素,那么作为结构与表现分离的一种实现,其作用应该是对文本起到很好的修饰作用,而不是把它用来表现文本。

阴影效果

使用伪元素:before 和 :after 。它们两个都是绝对定位,而且使用负z-index来放置到图片后方实现阴影效果。

CSS before和after伪类元素应用实例及分析

3D按钮

利用伪元素结合CSS3 box-shadow 来绘制一个令人吃惊的3D按钮,仅仅使用了CSS和单一的锚文本。伪元素:before 被用来在按钮的左侧添加数字“1”。

CSS before和after伪类元素应用实例及分析

叠加图像效果

使用伪元素来仅仅依靠一个图片标签创建一个“凌乱的”叠加图像效果也是可能的。伪元素用于建立一个图片叠加的错觉,通过使用z-index负值使“叠加”的图片在真正的图片后面来实现。

CSS before和after伪类元素应用实例及分析

Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn

Heiße KI -Werkzeuge

Undresser.AI Undress

Undresser.AI Undress

KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover

AI Clothes Remover

Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool

Undress AI Tool

Ausziehbilder kostenlos

Clothoff.io

Clothoff.io

KI-Kleiderentferner

AI Hentai Generator

AI Hentai Generator

Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

R.E.P.O. Energiekristalle erklärten und was sie tun (gelber Kristall)
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Beste grafische Einstellungen
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. So reparieren Sie Audio, wenn Sie niemanden hören können
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Chat -Befehle und wie man sie benutzt
4 Wochen vor By 尊渡假赌尊渡假赌尊渡假赌

Heiße Werkzeuge

Notepad++7.3.1

Notepad++7.3.1

Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version

SublimeText3 chinesische Version

Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1

Senden Sie Studio 13.0.1

Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6

Dreamweaver CS6

Visuelle Webentwicklungstools

SublimeText3 Mac-Version

SublimeText3 Mac-Version

Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Verwenden Sie den Pseudoklassenselektor :nth-child(n+3), um den Stil untergeordneter Elemente auszuwählen, deren Position größer oder gleich 3 ist Verwenden Sie den Pseudoklassenselektor :nth-child(n+3), um den Stil untergeordneter Elemente auszuwählen, deren Position größer oder gleich 3 ist Nov 20, 2023 am 11:20 AM

Verwenden Sie den Pseudoklassenselektor :nth-child(n+3), um den Stil untergeordneter Elemente auszuwählen, deren Position größer oder gleich 3 ist. Das spezifische Codebeispiel lautet wie folgt: HTML-Code: &lt;divid="container" &gt;&lt;divclass="item"&gt ;Erstes untergeordnetes Element&lt;/div&gt;&lt;divclass="item"&

CSS-Pseudo-Selektor-Lernen, Pseudoklassen-Selektor-Analyse CSS-Pseudo-Selektor-Lernen, Pseudoklassen-Selektor-Analyse Aug 03, 2022 am 11:26 AM

Im vorherigen Artikel „Css-Pseudo-Selektor-Lernen – Pseudo-Element-Selektor-Analyse“ haben wir etwas über Pseudo-Element-Selektoren gelernt, und heute werfen wir einen genaueren Blick auf Pseudo-Klassen-Selektoren. Ich hoffe, dass es für alle hilfreich ist!

Verwenden Sie den Pseudoklassenselektor :active, um CSS-Stile für Mausklickeffekte zu implementieren Verwenden Sie den Pseudoklassenselektor :active, um CSS-Stile für Mausklickeffekte zu implementieren Nov 20, 2023 am 09:26 AM

CSS-Stile, die den :active-Pseudoklassenselektor verwenden, um Mausklickeffekte zu erzielen. CSS ist eine kaskadierende Stylesheet-Sprache, die zur Beschreibung der Leistung und des Stils von Webseiten verwendet wird. :active ist ein Pseudoklassenselektor in CSS, der verwendet wird, um den Zustand eines Elements auszuwählen, wenn mit der Maus geklickt wird. Mithilfe des Pseudoklassenselektors :active können wir dem angeklickten Element bestimmte Stile hinzufügen, um den Mausklickeffekt zu erzielen. Im Folgenden finden Sie einen einfachen Beispielcode, der zeigt, wie Sie mit dem Pseudoklassenselektor :active einen Mausklickeffekt erzielen.

Der Unterschied zwischen insertbefore und before Der Unterschied zwischen insertbefore und before Nov 30, 2023 pm 02:34 PM

Der Unterschied zwischen insertbefore und before: 1. Verwendung; 3. Rückgabewert; 6. Automatische Erstellung von Elementen; Kettenruf; 11. Andere Unterschiede. Detaillierte Einführung: 1. Verwendung: insertBefore ist eine DOM-Methode, die direkt für jedes DOM-Element aufgerufen werden kann, before ist eine jQuery-Methode, die nur für jQuery-Objekte aufgerufen werden kann. 2. Parameter usw.

Was ist der Unterschied zwischen Pseudoklasse und Pseudoelement? Was ist der Unterschied zwischen Pseudoklasse und Pseudoelement? Dec 05, 2023 am 11:24 AM

Der Unterschied zwischen Pseudoklassen und Pseudoelementen ist: 1. Pseudoklassen werden verwendet, um bestimmten Elementen einige Spezialeffekte hinzuzufügen, während Pseudoelemente verwendet werden, um Inhalte oder Stile vor oder nach bestimmten Elementen hinzuzufügen. 2. Pseudoelemente werden normalerweise dargestellt durch einen einzelnen Doppelpunkt „:“, während Pseudoelemente normalerweise durch einen Doppelpunkt „::“ dargestellt werden.

Was ist der Unterschied zwischen Pseudoelementen und Pseudoklassen? Was ist der Unterschied zwischen Pseudoelementen und Pseudoklassen? Oct 09, 2023 pm 02:48 PM

Der Unterschied zwischen Pseudoelementen und Pseudoklassen ist: 1. Pseudoklassen sind Selektoren, mit denen ein bestimmter Zustand oder eine bestimmte Position eines Elements ausgewählt wird, während Pseudoelemente Selektoren sind, mit denen zusätzlicher Inhalt vor oder nach dem Inhalt eines Elements eingefügt wird 2. Die Funktion der Pseudoklasse besteht darin, den Stil des Elements entsprechend seinem Zustand oder seiner Position zu ändern, während die Funktion des Pseudoelements darin besteht, zusätzlichen Inhalt vor oder nach dem Inhalt des Elements einzufügen und seinen Stil zu ändern .

Implementieren Sie verschiedene Anwendungsszenarien des Pseudoklassenselektors CSS:target Implementieren Sie verschiedene Anwendungsszenarien des Pseudoklassenselektors CSS:target Nov 20, 2023 am 08:26 AM

Um verschiedene Anwendungsszenarien des CSS:target-Pseudoklassenselektors zu implementieren, sind spezifische Codebeispiele erforderlich. Der CSS:target-Pseudoklassenselektor ist ein häufig verwendeter CSS-Selektor, der bestimmte Elemente basierend auf dem Ankerpunkt (#) auswählen kann URL. In diesem Artikel stellen wir einige praktische Anwendungsszenarien für die Verwendung dieses Pseudoklassenselektors vor und stellen entsprechende Codebeispiele bereit. Umschalten des Stils des In-Page-Navigationslinks: Wenn der Benutzer auf den Navigationslink auf der Seite klickt, kann der :target-Pseudoklassenselektor verwendet werden, um den aktuell angeklickten Link auszuwählen.

Was sind Pseudoklassen und Pseudoelemente im Web? Was sind Pseudoklassen und Pseudoelemente im Web? Oct 12, 2023 pm 01:28 PM

Pseudoklassen und Pseudoelemente im Web sind eine spezielle Form von CSS-Selektoren, die zur Auswahl und Gestaltung bestimmter Elemente verwendet werden. Detaillierte Beschreibung: 1. Pseudo-Klasse ist ein Selektor, der zum Auswählen eines bestimmten Status oder Verhaltens eines Elements verwendet wird. Er beginnt mit einem Doppelpunkt (:) und wird verwendet, um dem Element zusätzliche Stile hinzuzufügen vor oder vor dem Inhalt des Elements, die nach dem generierten Inhalt eingefügt werden und mit einem Doppelpunkt (::) beginnen, werden verwendet, um zusätzlichen Inhalt zu erstellen, der nicht in der HTML-Struktur enthalten ist.

See all articles