CSS3---4.伪元素选择器

本文详细探讨了CSS伪元素E::before和E::after的使用方法及特性,包括它们的行内元素属性、如何转换为块级元素、必须添加的content属性以及在不同CSS版本中的变化。同时,文章还提到了这些伪元素在IE6至IE8中的兼容性问题,以及它们在CSS2与CSS3中的定义区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

a)重点:E::before、E::after
i.是一个行内元素,需要转换成块:display:block   float:**  position:
ii.必须添加content,哪怕不设置内容,也需要content:””
iii.E:after、E:before 在旧版本里是伪类,在新版本里是伪元素,新版本下E:after、E:before会被自动识别为E::after、E::before,按伪元素来对待,这样做的目的是用来做兼容处理
iv.E::before: 定义在一个元素的内容之前插入content属性定义的内容与样式
v.E::after: 定义在一个元素的内容之后插入content属性定义的内容与样式
vi.注意:
1.IE6、IE7与IE8(怪异模式Quirks mode)不支持此伪元素
2.CSS2中 E:before或者E:after,是属于伪类的,并且没有伪元素的概念,CSS3中 提出伪元素的概念 E::before和E::after,并且归属到了伪元素当中,伪类里就不再存在E:before或者   E:after伪类
b)E::first-letter文本的第一个字母或字(不是词组)
c)E::first-line 文本第一行
d)E::selection 可改变选中文本的样式
<style>
    *{
        padding: 0;
        margin: 0;
    }
    body{
        padding: 200px;
    }
    div{
        
        height: 200px;
        float: left;
    }
    div:nth-of-type(1){
        width: 300px;
        background-color: yellowgreen;
    }
    div:nth-of-type(2){
        width: 150px;
        background-color: skyblue;
        position: relative;
    }
    div:nth-of-type(2)::before,div:nth-of-type(2)::after{
        position: absolute;
        content: "";
        width: 40px;
        height: 40px;
        border-radius: 50%;
        background-color: #fff;

    }
    div:nth-of-type(2)::before{
        left: -20px;
        top:-20px;
    }
    div:nth-of-type(2)::after{
        left: -20px;
        bottom:-20px;
    }
</style>
<body>
    <div></div>
    <div></div>
</body>

浏览器渲染如下:
969404-20190313181303143-655976140.png

转载于:https://www.cnblogs.com/Tobenew/p/10524953.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值