css伪类和伪元素的区别,:before和::before的区别

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

(至关于一个特殊的class选择器,用来添加一些特殊效果)浏览器

伪元素为DOM树没有定义的虚拟元素。不一样于其余选择器,它不以元素为最小选择单元,它选择的是元素指定内容。好比::before表示选择元素内容的以前内容,也就是""::selection表示选择元素被选中的内容。ui

(至关于一个特殊的元素(div、span),能够用来存放一些特殊样式或者内容)spa

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

  • 伪类
Selector Meaning CSS
: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

 

  • 伪元素code

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

 

:before和::before的区别htm

  1. 两者写法是等效的,都表示伪元素。blog

  2. :before是CSS2的写法,::before是CSS3的写法。开发

  3. :before的兼容性比::before兼容性好,可是H5开发中建议使用::beforeget

注意:

  1. 伪元素要配合content属性一块儿使用

  2. 伪元素不会出如今DOM中,因此不能经过js来操做,仅仅是在 CSS 渲染层加入

  3. 伪元素的特效一般要使用:hover伪类样式来激活

.test:hover::before { /* 这时animation和transition才生效 */ }  

 

参考地址:https://www.cnblogs.com/ammyben/p/8012747.html

https://blog.csdn.net/yangxiaoyanger/article/details/79712180