- :after 伪元素在元素之后添加内容。
- :before伪元素在元素之前添加内容。
这个伪元素允许创作人员在元素内容的最后面插入生成内容。默认地,这个伪元素是行内元素,不过可以使用属性 dispiay 改变这一点。
:before和::before的区别?
单冒号(:)用于CSS3伪类,双冒号(::)用于CSS3伪元素。伪元素和伪类之所以这么容易混淆,是因为他们的效果类似而且写法相仿,但实际上 css3 为了区分两者,已经明确规定了伪类用一个冒号来表示,而伪元素则用两个冒号来表示。但因为兼容性的问题,所以现在大部分还是统一的单冒号,但是抛开兼容性的问题,我们在书写时应该尽可能养成好习惯,区分两者。
双冒号是在当前规范中引入的,用于区分伪类和伪元素。不过浏览器需要同时支持旧的已经存 在的伪元素写法,比如:first-line、:first-letter、:before、:after等,而新的在CSS3中引入的伪元素则不允许再支持旧的单冒号的写法。
那么现在就可以完整的回答标题中的问题了,对于CSS2之前已有的伪元素,比如:before,单冒号和双冒号的写法::before作用是一样的。
所以,如果你的网站只需要兼容webkit、firefox、opera等浏览器,建议对于伪元素采用双冒号的写法,如果不得不兼容IE浏览器,还是用CSS2的单冒号写法比较安全。
伪类种类

伪元素种类

eg
<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta http-equiv="X-UA-Compatible" content="IE=edge"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Document</title>
</head>
<style>.main-box {width: 100px;height: 100px;background-color:red;margin: 0 auto;line-height: 100px;position: relative;/* 改变主体某些样式来伴随更改分身的样式 *//* 水平方向旋转偏移量10度 */transform: skewX(10deg);/* transform: skewY(10deg); */text-align: center;/* 圆角是不会更改的, 我们需要在伪元素身上单独在添加一下 */border-radius: 20px;}.main-box::before,.main-box::after{border-radius: 20px;position: absolute;height: 100%;width: 100%;opacity: 0.6;left: 0;top: 0;}.main-box::before {content: "hello";background-color: skyblue;transform: translateX(-150%);}.main-box::after {content: "world";background-color: orange;transform: translateX(150%);}</style>
<body><div class="main-box">day day up</div>
</body>
</html>
效果
















