史上最全CSS3选择器集合

2017年10月08日 22:11:46益点益滴5947

资深前端一般都享受过jQuery选择器的“方便”,那么CSS样式层面有没有类似的选择器功能呢?答案是肯定的。CSS的世界绝不仅仅是固有的html标签、id和class那么单调,它也拥有多种选择器,CSS3选择器更是丰富。如果你还在为各种class命名发愁,而不知CSS选择器为何物,或者不知道怎么用的话,请一定看完这篇文章,相信多少能帮助解决一些烦恼,为你的css布局撰写助攻。

CSS样式是网页设计师可用的最强大的工具之一,它可以让我们在几分钟内改变一个网站的界面,而不用改动页面的标签。尽管很多时候,多数前端开发者也都意识到了它是有用的,但CSS选择器却远未发挥它们的潜力,有的时候我们还是趋向于使用过多的和无用的class、id、div、span等把我们的HTML搞的很凌乱。避免标签混乱保持其简洁和语义化是最佳方式,使用更精准的CSS选择器,它们可以定位于指定的元素而不用使用额外的html标签、以及class或id,通过这种方式也可以让我们的代码和样式更加灵活。

众所周知CSS1.0时候就有伪类选择器,比如:link、:hover等;而CSS2.0时代则引入了更多的属性选择器,比如input[type="text"]、p[class="important"]等;现在的CSS3.0版本选择器已经相当丰富,比如新加入的:nth-child(n)、:first-child、:last-child等选择器几乎已能满足各种场景。

以下是CSS选择器对照查询表:

1,基本选择器语法

选择器类型功能描述
* 通配选择器 选择文档中所以HTML元素
E 元素选择器选择指定类型的HTML元素
#id ID选择器选择指定ID属性值为“id”的任意类型元素
.class 类选择器选择指定class属性值为“class”的任意类型的任意多个元素
selector1,selectorN 群组选择器将每一个选择器匹配的元素集合并

 

2,层次选择器语法

选择器类型功能描述
E  F后代选择器(包含选择器)选择匹配的F元素,且匹配的F元素被包含在匹配的E元素内
E>F子选择器选择匹配的F元素,且匹配的F元素所匹配的E元素的子元素
E+F相邻兄弟选择器选择匹配的F元素,且匹配的F元素紧位于匹配的E元素的后面
E~F通用选择器选择匹配的F元素,且位于匹配的E元素后的所有匹配的F元素

 

3,动态伪类选择器语法

选择器类型功能描述
E:link链接伪类选择器  选择匹配的E元素,而且匹配元素被定义了超链接并未被访问过。常用于链接描点上
E:visited  链接伪类选择器选择匹配的E元素,而且匹配元素被定义了超链接并已被访问过。常用于链接描点上
E:active用户行为选择器选择匹配的E元素,且匹配元素被激活。常用于链接描点和按钮上
E:hover用户行为选择器选择匹配的E元素,且用户鼠标停留在元素E上。IE6及以下浏览器仅支持a:hover
E:focus用户行为选择器选择匹配的E元素,而且匹配元素获取焦点

 

4,目标伪类选择器

选择器功能描述
E:target选择匹配E的所有元素,且匹配元素被相关URL指向

 

5,UI元素状态伪类选择器语法

选择器类型功能描述
E:checked选中状态伪类选择器匹配选中的复选按钮或者单选按钮表单元素
E:enabled启用状态伪类选择器匹配所有启用的表单元素
E:disabled不可用状态伪类选择器匹配所有禁用的表单元素

 6,结构伪类选择器使用语法

选择器功能描述
E:fisrt-child作为父元素的第一个子元素的元素E。与E:nth-child(1)等同
E:last-child作为父元素的最后一个子元素的元素E。与E:nth-last-child(1)等同
E:root选择匹配元素E所在文档的根元素。在HTML文档中,根元素始终是html,此时该选择器与html类型选择器匹配的内容相同
E F:nth-child(n)选择父元素E的第n个子元素F。其中n可以是整数(1,2,3)、关键字(even,odd)、可以是公式(2n+1),而且n值起始值为1,而不是0.
E F:nth-last-child(n)选择父元素E的倒数第n个子元素F。此选择器与E:nth-child(n)选择器计算顺序刚好相反,但使用方法都是一样的,其中:nth-last-child(1)始终匹配最后一个元素,与last-child等同
E:nth-of-type(n)选择父元素内具有指定类型的第n个E元素
E:nth-last-of-type(n)选择父元素内具有指定类型的倒数第n个E元素
E:first-of-type选择父元素内具有指定类型的第一个E元素,与E:nth-of-type(1)等同
E:last-of-tye选择父元素内具有指定类型的最后一个E元素,与E:nth-last-of-type(1)等同
E:only-child选择父元素只包含一个子元素,且该子元素匹配E元素
E:only-of-type选择父元素只包含一个同类型子元素,且该子元素匹配E元素
E:empty选择没有子元素的元素,而且该元素也不包含任何文本节点

注:(1),“ul>li:nth-child(3)”表达的并不是一定选择列表ul元素中的第3个子元素li,仅有列表ul中第3个li元素前不存在其他的元素,命题才有意义,否则不会改变列表第3个li元素的样式。

(2),:nth-child(n)  中参数只能是n,不可以用其他字母代替。

(3),:nth-child(odd) 选择的是奇数项,而使用:nth-last-child(odd) 选择的却是偶数项

例子:

li:nth-child(3){background:orange;}

li:nth-child(3n){background:orange;}

li:nth-child(n+3){background:orange;}

li:nth-child(-n+3){background:orange;}

li:nth-child(3n+1){background:orange;}

li:nth-last-child(4) {background: red;}

7,否定伪类选择器

选择器功能描述
E:not(F)匹配所有除元素F外的E元素

8,属性选择器语法

选择器功能描述
[attribute]用于选取带有指定属性的元素。
[attribute=value]用于选取带有指定属性和值的元素。
[attribute~=value]用于选取属性值中包含指定词汇的元素。
[attribute|=value]用于选取带有以指定值开头的属性值的元素,该值必须是整个单词。
[attribute^=value]匹配属性值以指定值开头的每个元素。
[attribute$=value]匹配属性值以指定值结尾的每个元素。
[attribute*=value]匹配属性值中包含指定值的每个元素。

注:例<div class="links item"></div>其中a[class="links"]{……} 是找不到匹配元素的,只有a[class="links item"]{……}才能匹配到。

超赞,真给力!嗯,必须鼓励~

打赏1
账号:mxy310@163.com[复制]
账号:77940140[复制]