温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

css中伪类和伪元素的区别有哪些

发布时间:2022-03-10 15:33:59 来源:亿速云 阅读:144 作者:iii 栏目:web开发

本篇内容介绍了“css中伪类和伪元素的区别有哪些”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

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

  (相当于一个特殊的class选择器,用来添加一些特殊效果)

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

  (相当于一个特殊的元素(p、span),可以用来存放一些特殊样式或者内容)

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

  伪类

  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

  伪元素

  Selector Meaning CSS

  ::first-letter 选择指定元素的第一个单词 1

  ::first-line 选择指定元素的第一行 1

  ::after 在指定元素的内容前面插入内容 2

  ::before 在指定元素的内容后面插入内容 2

  ::selection 选择指定元素中被用户选中的内容 3

  :before和::before的区别

  二者写法是等效的,都表示伪元素。

  :before是CSS2的写法,::before是CSS3的写法。

  :before的兼容性比::before兼容性好,但是H5开发中建议使用::before

  注意:

  伪元素要配合content属性一起使用

  伪元素不会出现在DOM中,所以不能通过js来操作,仅仅是在CSS渲染层加入

  伪元素的特效通常要使用:hover伪类样式来激活

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



css中伪类和伪元素的区别有哪些

“css中伪类和伪元素的区别有哪些”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

css
AI