大家好,欢迎来到IT知识分享网。
前言
在CSS1和CSS2中对伪类和伪元素没有做出很明显的区别定义,而二者在语法是一样的,都是以:
开头,这造成很多人会将某些伪元素误认为是伪类,如:before
,:after
;而在CSS3给出的定义中,二者区别更为明显,也更容易理解。
伪类
伪类用于选择DOM树之外的信息,包含那些 匹配指定状态的元素 ,比如
:visited
,:active
;或是 不能用简单选择器进行表示的信息 ,后者包含那些满足一定逻辑条件的DOM树中的元素,比如:first-child
,:first-of-type
,:target
。
常用伪类有:
Selector | Meaning |
---|---|
: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
表示选择元素被选中的内容。
Selector | Meaning |
---|---|
::first-letter | 选择指定元素的第一个单词 |
::first-line | 选择指定元素的第一行 |
::after | 在指定元素的内容前面插入内容 |
::before | 在指定元素的内容后面插入内容 |
::selection | 选择指定元素中被用户选中的内容 |
区别
在CSS3中,伪元素以::
开头,但因为CSS1、CSS2的历史原因,浏览器对以:
开头的伪元素也继续支持,但建议规范书写为::
开头。
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/22096.html