css伪类和伪元素

伪,假的意思。把伪字拿掉,可以看出它们的本质区别,一个是类(class),一个是元素(tag),本质区别是有没有创建新的元素,改变html结构(抽象层面上)。

常见的伪类有::link , :visited , :hover , :actived , :focus(向拥有键盘输入焦点的元素添加样式) :first-child(向元素的第一个子元素添加样式) , :lang(向带有lang属性特定值的元素添加样式)

常见的伪元素有:::before , ::after , ::first-letter(向文本的第一个字母添加样式) , ::first-line(向文本的首行添加样式)

注:::first-letter和::first-line只能作用于块级元素。

css3中伪类的定义: 

伪类存在的意义是为了通过选择器找到那些不存在与DOM树中的信息以及不能被常规CSS选择器获取到的信息。

伪类由一个冒号:开头,冒号后面是伪类的名称和包含在圆括号中的可选参数。

任何常规选择器可以再任何位置使用伪类。伪类语法不区别大小写。一些伪类的作用会互斥,另外一些伪类可以同时被同一个元素使用。并且,为了满足用户在操作DOM时产生的DOM结构改变,伪类也可以是动态的。

伪元素定义:

伪元素在DOM树中创建了一些抽象元素,这些抽象元素是不存在于文档语言里的(可以理解为html源码)。比如:documen接口不提供访问元素内容的第一个字或者第一行的机制,而伪元素可以使开发者可以提取到这些信息。并且,一些伪元素可以使开发者获取到不存在于源文档中的内容(比如常见的::before,::after)。

伪元素的由两个冒号::开头,然后是伪元素的名称。

使用两个冒号::是为了区别伪类和伪元素(CSS2中并没有区别)。当然,考虑到兼容性,CSS2中已存的伪元素仍然可以使用一个冒号:的语法,但是CSS3中新增的伪元素必须使用两个冒号::。

一个选择器只能使用一个伪元素,并且伪元素必须处于选择器语句的最后。

(为保证兼容,伪元素在书写的时候还是采用一个冒号开头)

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 伪类与伪元素 css引入伪类和伪元素概念是为了格式化文档树以外的信息。也就是说,伪类和伪元素是用来修饰不在文档树中...
    落花的季节阅读 350评论 0 1
  • 本文转载自:众成翻译译者:为之漫笔链接:http://www.zcfy.cc/article/239原文:http...
    极乐君阅读 7,403评论 1 62
  • CSS伪类: link:未被访问的链接 visited:被访问过后的样式 hover:鼠标放上去的样式 activ...
    尤樊容阅读 314评论 0 0
  • 1. 伪类 & 伪元素 伪类和伪元素用来修饰不在文档树中的部分 伪类:用于当已有元素处于的某个状态时,为其添加对应...
    杨慧莉阅读 593评论 0 5
  • 命运就握在自己的手掌 文/长河映日 前途越是被云雾遮挡 就越要坚定信念树立理想 人生越是遇到大风大浪 就越要勇敢的...
    长河印日阅读 250评论 0 4