伪元素
作者: dkvirus 发表于: 2018-06-17 19:25:00 最近更新: 2018-07-27 22:09:18

学习 css 经常会遇到 :hover、:nth-child 和 ::after、::before 这种东东,很容易将二者混为一谈。看了 starof 的文章之后才算豁然开朗。转载自 starof 的 《::before和::after伪元素的用法》

一、介绍

CSS3为了区分伪类和伪元素,伪元素采用双冒号写法。

常见伪类 —— :hover, :link, :active, :target, :not(), :focus。
常见伪元素 —— ::first-letter, ::first-line, ::before, ::after, ::selection。

::before 和 ::after 下特有的 content,用于在 css 渲染中向元素逻辑上的头部或尾部添加内容。
这些添加不会出现在 DOM 中,不会改变文档内容,不可复制,仅仅是在 css 渲染层加入。
所以不要用 ::before 或 ::after 展示有实际意义的内容,尽量使用它们显示修饰性内容,例如图标。

举例:网站有些联系电话,希望在它们前加一个 icon ☎,就可以使用 ::before 伪元素,如下:

1
2
3
4
5
6
7
8
9
<!DOCTYPE html>
<meta charset="utf-8" />
<style type="text/css">
.phoneNumber::before {
content:'\260E';
font-size: 15px;
}
</style>
<p class="phoneNumber">12345645654</p>

伪元素图1

Note:这些特殊字符的html,js和css的写法是不同的,具体可查看 html特殊字符的html,js,css写法汇总

二、content 属性

::before 和 ::after 必须配合 content 属性来使用,content 用来定义插入的内容,content 必须有值,至少是空。默认情况下,伪类元素的 display 是默认值 inline,可以通过设置 display:block 来改变其显示。

1. String

使用引号包一段字符串,将会向元素内容中添加字符串。如:a:after{content:””}

1
2
3
4
5
6
7
8
9
10
11
12
13
<!DOCTYPE html>
<meta charset="utf-8" />
<style type="text/css">
p::before{
content: "《";
color: blue;
}
p::after{
content: "》";
color: blue;
}
</style>
<p>平凡的世界</p>

伪元素图2

2. attr()

通过 attr() 调用当前元素的属性,比如将图片 alt 提示文字或者链接的 href 地址显示出来。

1
2
3
4
5
6
<style type="text/css">
a::after{
content: "(" attr(href) ")";
}
</style>
<a href="http://www.cnblogs.com/starof">starof</a>

伪元素图3

3. url()/uri()

用于引用媒体文件。举例:“百度”前面给出一张图片,后面给出 href 属性。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
<style>
a::before{
content: url("https://www.baidu.com/img/baidu_jgylogo3.gif");
}
a::after{
content:"("attr(href)")";
}
a{
text-decoration: none;
}
</style>
---------------------------
<body>
<a href="http://www.baidu.com">百度</a>
</body>

伪元素图4

4. counter()

调用计数器,可以不使用列表元素实现序号功能。

配合 counter-increment 和 counter-reset 属性使用:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
<style>
body{
counter-reset: section;
}
h1{
counter-reset: subsection;
}
h1:before{
counter-increment:section;
content:counter(section) "、";
}
h2:before{
counter-increment:subsection;
content: counter(section) "." counter(subsection) "、";
}
</style>
<body>
<h1>HTML tutorials</h1>
<h2>HTML Tutorial</h2>
<h2>XHTML Tutorial</h2>
<h2>CSS Tutorial</h2>

<h1>Scripting tutorials</h1>
<h2>JavaScript</h2>
<h2>VBScript</h2>

<h1>XML tutorials</h1>
<h2>XML</h2>
<h2>XSL</h2>
</body>

伪元素图5

三、小 demo

1. 做出各种图形效果

举例:一个六角星。#star-six 的 div 是一个正三角行,#star-six::after 是一个倒三角形,通过绝对定位,调整其位置即可实现六角星的效果。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
<style>
#star-six {
width: 0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-bottom: 100px solid red;
position: relative;
}
#star-six::after {
width: 0;
height: 0;
border-left: 50px solid transparent;
border-right: 50px solid transparent;
border-top: 100px solid red;
position: absolute;
content: "";
top: 30px;
left: -50px;
}
</style>
<body>
<div id="star-six"></div>
</body>

伪元素图6

2. 不使用图片创建小图标

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
<style type="text/css">
#phone{
width:50px;
height:50px;
border-left:6px solid #EEB422;
border-radius:20%;
transform:rotate(-30deg);
-webkit-transform:rotate(-30deg);
margin:20px;
margin-right:0px;
position:relative;
display: inline-block;
top: -5px;
}
#phone:before{
width:15px;
height:15px;
background:#EEB422;
border-radius: 20%;
content: "";
position: absolute;
left:-2px;top: 1px;
}
#phone:after{
width:15px;
height:15px;
background:#EEB422;
border-radius: 20%;
content: "";
position: absolute;
left:-3px;
top: 34px;
}
</style>
<div id="wraper">
<div id="phone"></div>
</div>

伪元素图7

3. 显示打印网页的URL

1
2
3
4
5
6
7
8
<style>
a::after {
content: " (" attr(href) ") ";
}
</style>
<body>
<a href="http://www.baidu.com">百度</a>
</body>

伪元素图8

4. 超链接特效

举例:配合 CSS定位实现一个鼠标移上去,超链接出现方括号的效果

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<meta charset="utf-8" />
<style type="text/css">
body{
background-color: #425a6c;
}
a {
position: relative;
display: inline-block;
outline: none;
color: #fff;
text-decoration: none;
font-size: 32px;
padding: 5px 20px;
}
a:hover::before, a:hover::after { position: absolute; }
a:hover::before { content: "\5B"; left: -10px; }
a:hover::after { content: "\5D"; right: -10px; }
</style>
<a>鼠标移上去出现方括号</a>

伪元素图9

四、实践

1. img 标签不能设置 ::after?

本来想利用 ::after 给本站上的图片加上水印,无奈发现没法给 img 设置 ::after。

经过一番搜查之后,发现 img 标签下面不能再写子元素,因此没法用伪元素,换言之,伪元素只能应用在可以包裹子标签的元素上。

首页
友链
归档
dkvirus
动态
RSS