伪类与伪元素的区别

本文详细介绍了CSS中的伪类和伪元素概念,包括它们的定义、语法、使用场景及区别。列举了多种伪类如:hover、:first-child等,以及伪元素如::before、::after等,帮助读者理解如何在网页设计中应用这些特性。

定义:

1,伪类:伪类用于选择DOM树之外的信息,或是不能用简单选择器进行表示的信息。包含那些匹配指定状态的元素。用于向某些选择器添加特殊效果。使用开头。

2,伪元素:伪元素为DOM树没有定义的虚拟元素。不同于其他选择器,它不以元素为最小选择单元,它选择的是元素指定内容。用于向某些选择器设置特殊效果。使用::开头。

 

语法:

在CSS3中,伪类与伪元素在语法上也有所区别,伪元素修改为以::开头。但因为历史原因,浏览器对以:开头的伪元素也继续支持,但建议规范书写为::开头。

 

伪类/伪元素一览表:

  • 伪类

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

注意:p:first-child表示选择的元素既要是p标签,同时要是其父元素的第一个子元素,不要错误认为是表示p元素的第一个子元素;同理,p:first-of-type表示选择的元素要是p标签,同时要是其父元素的第一个p标签元素;其他类似的伪类含义相似。

  • 伪元素

    SelectorMeaningCSS
    ::first-letter选择指定元素的第一个单词1
    ::first-line选择指定元素的第一行1
    ::after在指定元素的内容前面插入内容2
    ::before在指定元素的内容后面插入内容2
    ::selection选择指定元素中被用户选中的内容3

伪类与伪元素的特性及其区别:

  1. 伪类本质上是为了弥补常规CSS选择器的不足,以便获取到更多信息;
  2. 伪元素本质上是创建了一个有内容的虚拟容器;
  3. CSS3中伪类和伪元素的语法不同;
  4. 可以同时使用多个伪类,而只能同时使用一个伪元素;
 
参考链接:https://www.cnblogs.com/ihardcoder/p/5294927.html
 

  

转载于:https://www.cnblogs.com/xu-xiao-jin/p/9832547.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值