看一遍让你永远记住伪类和伪元素的区别

前言

这些天在做笔记的时候发现自己对伪类和伪元素区分的还是不够清楚 。我就到网上收集了各种之资料,我也是弄清楚了它们之间 的区别,相信看了这篇博客你也会更加清楚。

伪类

伪类用于选择DOM树之外的信息,包含那些 匹配指定状态的元素 ,比如:visited,:active;或是 不能用简单选择器进行表示的信息 ,后者包含那些满足一定逻辑条件的DOM树中的元素,比如:first-child,:first-of-type,:target。

常用伪类有:

:active 选择正在被激活的元素(匹配指定状态)
:hover 选择被鼠标悬浮着的元素(匹配指定状态)
:link 选择未被访问的元素 (匹配指定状态)
:visited 选择已被访问的元素(匹配指定状态)
:first-child 选择满足是其父元素的第一个子元素的元素
:lang(value) 选择带有指定 lang 属性的元素
:focus 选择拥有键盘输入焦点的元素
:enable 选择每个已启动的元素
:disable 选择每个已禁止的元素
:checked 选择每个被选中的元素
:target 选择当前的锚点元素
:first-of-type 选择满足是其父元素的第一个某类型子元素的元素
:last-of-type 选择满足是其父元素的最后一个某类型子元素的元素
:only-of-type 选择满足是其父元素的唯一一个某类型子元素的元素
:nth-of-type(n) 选择满足是其父元素的第n个某类型子元素的元素
:nth-last-of-type(n) 选择满足是其父元素的倒数第n个某类型的元素
:only-child 选择满足是其父元素的唯一一个子元素的元素
:last-child 选择满足是其父元素的最后一个元素的元素
:nth-child(n) 选择满足是其父元素的第n个子元素的元素
:nth-last-child(n) 选择满足是其父元素的倒数第n个子元素的元素
:empty 选择满足没有子元素的元素
:in-range 选择满足值在指定范围内的元素
:out-of-range 选择值不在指定范围内的元素
:invalid 选择满足值为无效值的元素
:valid 选择满足值为有效值的元素
:not(selector) 选择不满足selector的元素
:optional 选择为可选项的表单元素,即没有“required”属性
:read-only 选择有"readonly"的表单元素
:read-write 选择没有"readonly"的表单元素
:root 选择根元素

注意:

p:first-child,表示选择的元素既要是p标签,又要是其父元素的第一个子元素,不要错认为是表示p元素的第一个子元素;
同理,p:first-of-type表示选择的元素既要是p标签,又要是其父元素的第一个p标签元素。

伪元素

伪元素为DOM树没有定义的虚拟元素。不同于其他选择器,它不以元素为最小选择单元,它选择的是元素指定内容。比如::before表示选择元素内容的之前内容,也就是"";::selection表示选择元素被选中的内容。
::first-letter 选择指定元素的第一个单词
::first-line 选择指定元素的第一行
::after 在指定元素的内容前面插入内容
::before 在指定元素的内容后面插入内容
::selection 选择指定元素中被用户选中的内容

区别

在CSS3中,伪元素以::开头,但因为CSS1、CSS2的历史原因,浏览器对以:开头的伪元素也继续支持,但建议规范书写为::开头。

  • 1
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值