css伪选择器使用总结——css中关于伪类和伪元素的知识总汇

时间: 2017-10-27阅读: 895标签: 伪类

CSS 伪类用于向某些选择器添加特殊的效果,而CSS引入伪类和伪元素的概念是为了实现基于文档树之外的信息的格式化。这里讲总结关于css伪类和伪元素的相关使用

伪元素 

:before/:before   在某个元素之前插入一些内容;

::after/:after    在某个元素之后插入一些内容;

::first-letter/:first-letter  为某个元素中的文字的首字母或第一个字使用样式;

::first-line/:first-line    为某个元素的第一行文字使用样式;

::selection     匹配用户被用户选中或者处于高亮状态的部分;

::placeholder     匹配占位符的文本,只有元素设置了placeholder属性时,该伪元素才能生效;

::backdrop(处于试验阶段)  用于改变全屏模式下的背景颜色,全屏模式的默认颜色为黑色。该伪元素只支持双冒号的形式;

伪类

(1)表示状态:

:link   选择未访问的链接;

:visited  选择已访问的链接;

:hover  选择鼠标指针移入链接;

:active  被激活的链接,即按下单击鼠标左键但未松开;

:focus  选择获取焦点的输入字段;

(2)结构化伪类:

:not      否定伪类,用于匹配不符合参数选择器的元素;

:first-child   匹配元素的第一个子元素;

:last-child    匹配元素的最后一个子元素;

first-of-type  匹配属于其父元素的首个特定类型的子元素的每个元素;

:last-of-type  匹配元素的最后一个子元素;

:nth-child    :nth-child根据元素的位置匹配一个或者多个元素,它接受一个an+b形式的参数(an+b最大数为匹配元素的个数);

:nth-last-child  :nth-last-child与:nth-child相似,不同之处在于它是从最后一个子元素开始计数的;

:nth-of-type    :nth-of-type与nth-child相似,不同之处在于它是只匹配特定类型的元素;

:nth-last-type    :nth-last-of-type与nth-of-type相似,不同之处在于它是从最后一个子元素开始计数的;

:only-child      当元素是其父元素中唯一一个子元素时,:only-child匹配该元素;

:only-of-type  当元素是其父元素中唯一一个特定类型的子元素时,:only-child匹配该元素;

:target       当URL带有锚名称,指向文档内某个具体的元素时,:target匹配该元素;

(3)表单相关伪类:

:checked  匹配被选中的input元素,这个input元素包括radio和checkbox;

:default    匹配默认选中的元素,例如:提交按钮总是表单的默认按钮;

:disabled   匹配禁用的表单元素;

:empty     匹配没有子元素的元素。如果元素中含有文本节点、HTML元素或者一个空格,则:empty不能匹配这个元素;

:enabled  匹配没有设置disabled属性的表单元素;

:in-range    匹配在指定区域内元素;

:out-of-range    与:in-range相反,它匹配不在指定区域内的元素;

:indeterminate  indeterminate的英文意思是“不确定的”。当某组中的单选框或复选框还没有选取状态时,:indeterminate匹配该组中所有的单选框或复选框;

:valid     匹配条件验证正确的表单元素;

:invalid    与:valid相反,匹配条件验证错误的表单元素;

:optional  匹配是具有optional属性的表单元素。当表单元素没有设置为required时,即为optional属性;

:required  匹配设置了required属性的表单元素;

:read-write  匹配处于编辑状态的元素。input,textarea和设置了contenteditable的HTML元素获取焦点时即处于编辑状态;

:scope(处于试验阶段)  匹配处于style作用域下的元素。当style没有设置scope属性时,style内的样式会对整个html起作用;

(4)语言相关伪类:

:dir(处于实验阶段)  匹配指定阅读方向的元素,当HTML元素中设置了dir属性时该伪类才能生效。现时支持的阅读方向有两种:ltr(从左往右)和rtl(从右往左)。目前,只有火狐浏览器支持:dir伪类,并在火狐浏览器中使用时需要添加前缀( -moz-dir() );

:lang    匹配设置了特定语言的元素,设置特定语言可以通过为了HTML元素设置lang=””属性,设置meta元素的charset=””属性,或者是在http头部上设置语言属性;

(5)其他伪类:

 :root  匹配文档的根元素。一般的html文件的根元素是html元素,而SVG或XML文件的根元素则可能是其他元素;

:fullscreen  匹配处于全屏模式下的元素。全屏模式不是通过按F11来打开的全屏模式,而是通过Javascript的Fullscreen API来打开的,不同的浏览器有不同的Fullscreen  API。目前,:fullscreen需要添加前缀才能使用;

备注:

伪元素虽然强大,但是还是有一些特定的标签是不支持伪元素 before 和 after 的。诸如 <img> 、<input>、<iframe>,这几个标签是不支持类似 img::before 这样使用。究其原因,要想要标签支持伪元素,需要这个元素是要可以插入内容的,也就是说这个元素要是一个容器,而 input,img,iframe 等元素都不能包含其他元素,所以不能通过伪元素插入内容  


吐血推荐

1.阿里云: 本站目前使用的是阿里云主机,安全/可靠/稳定。点击领取2000元代金券、了解最新阿里云产品的各种优惠活动点击进入...

2.腾讯云: 提供云服务器、云数据库、云存储、视频与CDN、域名等服务。腾讯云各类产品的最新活动,优惠券领取点击进入...

3.站长广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入...

链接: http://www.fly63.com/article/detial/20

css伪类和伪元素

伪类和伪元素,对于绝大多数同学来说,都是耳熟能详的名字,但确实又有很多人搞不清楚它们之间的区别,以致于混淆概念。而当概念都混淆的时候,也往往意味着你不会经常使用它,怕出错,怕用不好

理解:before伪类搭配vertical-align:middle实现垂直居中的原理

总所周知,Css如何实现元素垂直居中?已经是一个老生常谈的问题了,这个问题目前已经有了许多解决方案,这些方案也都有各自适用的场景以及优缺点,大致如下:

css中:focus伪类的使用

当元素获取到焦点之后,若该元素是一个有效的链接,则通过“Enter”键即可进入该链接地址;在页面中也可以通过\\\"Tab\\\"键,遍历所有的可获得焦点的元素,使其获得焦点;

html中a标签的4个伪类样式

在CSS超链接的属性中,有四个连接方式:a:link a:hover a:visited a:acticve,之前在使用的时候一直是按照自认为的顺序中去写的,就是 L H V A的排序方式,然而有些时候却发现并不起作用了

中间文字,两边横线的css3伪类的使用

CSS伪类是用来添加一些选择器的特殊效果。使用了css3的伪类,即相当于是在一个div中写入文字,然后在它前后各加了一个div,然后进行位置及宽高的调节。代码中只写一个div,然后在css样式中,对该div设置flex布局

善用CSS伪类,不用JS也能做出选项卡功能

本篇文章的技术给予选项卡UI另一种开发的选择,Radio button的特性还有很多应用可以做(如Switcher),只要善用HTML表单元素与CSS的一些技巧,也能玩出很多有趣的功能,甚至替代JavaScript的部份工作.

css否定伪类:not(s)

:not(X)是CSS中的一个否定伪类(选择器),并且接受一个简单的选择器作为参数。本质上,可以使任一其他选择器(作为参数)。:not(选择器)匹配传递参数选择器未选择的元素。传递参数或许不包括增加的选择器或者伪元素选择器。

深入理解CSS伪类

伪类经常与伪元素混淆,伪元素的效果类似于通过添加一个实际的元素才能达到,而伪类的效果类似于通过添加一个实际的类来达到。实际上css3为了区分两者,已经明确规定了伪类用一个冒号来表示,而伪元素则用两个冒号来表示。本文将详细介绍伪类的详细知识

CSS3新增的伪类有哪些 与 居中div的多种方法

CSS3新增伪类有那些?p:first-of-type:选择属于其父元素的首个<p>元素,p:last-of-type:选择属于其父元素的最后<p>元素,p:only-of-type:属于父元素的特定类型的唯一子元素,p:only-child:属于父元素的唯一子元素的每个<p>元素;p:nth-child(2)

css链接link_CSS :link 伪类

链接可以使用任何css属性,包括字体、颜色、背景等等、链接有四个状态,可在四个状态时设置不同的属性,当为链接的不同状态设置样式时,需要遵循a:hover 必须位于a:link 和a:visited之后,a:active 必须位于 a:hover 之后

fly63.com版权所有,内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权,请与小编联系!情况属实本人将予以删除!

广告赞助文章投稿关于web前端网站点搜索站长推荐网站地图站长QQ:522607023

小程序专栏: 土味情话心理测试脑筋急转弯幽默笑话段子句子语录成语大全