博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CSS :befor :after 伪元素的妙用
阅读量:5811 次
发布时间:2019-06-18

本文共 1757 字,大约阅读时间需要 5 分钟。

  本篇重点介绍CSS中的:befor、:after创建的伪元素几种使用场景,如填充文本、作为iconfont、进度线、时间线以及几何图形。

1. 介绍

1.1 说明

CSS中的:befor、:after都会创建一个伪元素,其中:befor创建的伪元素是所选元素的第一个子元素,:after创建的伪元素是所选元素的最后一个子元素。

:befor、:after创建的伪元素默认样式为内联样式

 

1.2 语法

/* CSS3 */selector::before/* CSS2 */selector:before

CSS3引入了 ::(两个冒号)是用来区分伪类(:一个冒号)和伪元素(::两个冒号)。

伪类:操作元素本身,如 :hover、:first-child、:focus等等。

伪元素:操作元素的子元素,如 ::before、::after、::content等等。

在IE8中只支持:(一个冒号),所以为了兼容这些浏览器也可以使用 :befor、:after。

 

1.3 content属性

content 属性表示伪元素填充的内容。

示例

CSS

.test-div {    width: 100px;    height: 100px;    margin-left: 20px;    background-color: #eee;}.test-div::before {    content: "♥";    color: red;}.test-div::after {    content: "♥";    color: blue;}

HTML页面

效果

 

 

1.4 可替换元素

可替换元素(replaced element):其展现不由CSS来控制的。这些元素是一类外观渲染独立于CSS的对象。

典型的可替换元素有<iframe>、<img>、 <object>、 <video> 以及 表单元素,如<textarea>、 <input> 。

某些元素只在一些特殊情况下表现为可替换元素,例如 <audio> 和 <canvas> 。

:befor :after 在此类元素内是不生效的。

 

1.5 浏览器支持情况

IE9版本才开始完全支持 :befor :after ,Chrome、Firefox现都已全线支持。

IE Edge Firefox Chrome Android 
Chrome
iOS 
Safari
9 all 2 all all  all

 

 

2. 应用场景

2.1 支持文本字符

说明:content属性支持文本字符。

示例

 

2.2 支持iconfont

说明:content属性也支持iconfont字体图表的展示。这也是使用最多的场景。

示例:此示例已引用了阿里iconfont图标库

 

2.3 进度线与时间线

说明::befor :after创建的伪元素可以以线条方式定位在元素周边的指定位置上,如进度线和时间线。

1) 进度线

 

2) 时间线

 

2.4 几何图形

说明:通过设置 :befor :after 伪元素的border相关属性,可创建非常多的几何图形;如三角形、多边形、五角星等等。

1) 矩形

说明:默认情况下,:befor :after 伪元素的border边框属性与其他HTML元素一样。

CSS

div::before {    width: 0px;    height: 0px;    content: '';    position: absolute;    border-top: 50px solid #f50000;    border-right: 50px solid #6cc361;    border-bottom: 50px solid #6167c3;    border-left: 50px solid #fa00d9;}

效果

 

2) 三角形

说明:显示某一方位的border,并隐藏左右2边的border(背景设置为透明),可让伪元素显示三角形的形状。

示例

 

3. 扩展阅读

MDN ::before:

MDN ::after:

::before、::after介绍:

CSS 几何图形:

 

转载地址:http://lwjbx.baihongyu.com/

你可能感兴趣的文章
html语言
查看>>
从源码看集合ArrayList
查看>>
spring-boot支持websocket
查看>>
菜鸟笔记(一) - Java常见的乱码问题
查看>>
我理想中的前端工作流
查看>>
记一次Git异常操作:将多个repository合并到同一repository的同一分支
查看>>
CodeIgniter 3.0 新手捣鼓源码(一) base_url()
查看>>
Chrome 广告屏蔽功能不影响浏览器性能
查看>>
vSphere 6将于2月2日全球同步发表
查看>>
Android状态栏实现沉浸式模式
查看>>
让你的APP实现即时聊天功能
查看>>
iOS 绝对路径和相对路径
查看>>
使用Openfiler搭建ISCSI网络存储
查看>>
应用新安全组 - 每天5分钟玩转 OpenStack(116)
查看>>
iOS - UIViewController
查看>>
IntPtr 转 string
查看>>
学生名单
查看>>
(转) 多模态机器翻译
查看>>
【官方文档】Nginx负载均衡学习笔记(三) TCP和UDP负载平衡官方参考文档
查看>>
矩阵常用归一化
查看>>