css3伪元素怎么用
css3有很多伪类元素,今天为大家介绍一下 ::before 和 ::after 的用法。
一、与普通元素一样可以给其添加样式
比如说我想在文字前面添加一个图标,如果我用普通元素写的话我可以这样写:/*CSS*/
.del{ font-size: 20px;}
.del i{
display: inline-block;
width: 20px;
height: 25px;
margin-right: 2px;
vertical-align: middle;
background: url("imgs/delete.png") no-repeat center;
background-size: 100%;
}
.del span{ vertical-align: middle;}
/*HTML*/
但是放个空的 i 标签总感觉很不爽,直接把它去掉吧!/*CSS*/
.del{ font-size: 20px;}
.del::before{
content: "";
display: inline-block;
width: 20px;
height: 25px;
margin-right: 2px;
vertical-align: middle;
background: url("imgs/delete.png") no-repeat center;
background-size: 100%;
}
.del span{ vertical-align: middle;}
/*HTML*/
这里就直接用::before伪元素代替了空的 i 标签,两者效果相同:
同样利用这一点,我们可以使用::after伪元素解决经典清除浮动的问题:.clearfix::after{
display:block;
clear:both;
content:"";
overflow:hidden;
height:0;
}
当然,如果你网站还需要兼容IE8,那还是用:after吧,::after不兼容。
二、在元素中插入文本
有时候我可能需要在许多元素中同时加入相同的文字,那么可以考虑用这两个伪元素。例如:/*CSS*/
.up:after{
content: '↑';
color: #f00;
}
.down:after{
content: '↓';
color: #0f0;
}
/*HTML*/
上升
下降
实现效果如下:
三、在元素中插入图像
实现类似本文第一个例子中的图片加文字效果,也可以使用伪元素直接插入图片而不需要使用背景图,就像这样:/*CSS*/
.del{
font-size: 20px;
}
.del::before{
content: url("imgs/delete.png");
display: inline-block;
margin-right: 2px;
vertical-align: middle;
}
.del span{
vertical-align: middle;
}
但是需要非常注意的是,使用这种方式插入的图片并不能通过控制伪元素的大小来改变图片的大小,只能引入固定大小的图片(这个略坑啊...),所以个人觉得最好还是老老实实用背景图片比较好。
四、插入连续项目编号/*CSS*/
ul li{
list-style: none;
counter-increment: number; //number相当于是个变量,随便取名就好,在伪元素中调用
}
ul li::before{
content: counter(number)".";
font-weight: bold;
} //注意这里不同于JS,counter(number)与"."之间不需要加任何东西,直接连接就好
/*HTML*/
我的爱好:
- 吃饭
- 睡觉
- 打豆豆
效果如下:
更多CSS相关技术文章,请访问CSS3答疑栏目进行学习!