您现在的位置:首页 >> 前端 >> 内容

CSS选择器详细总结

时间:2015/6/30 11:41:31 点击:

  核心提示:一、基本选择器 序号 选择器 含义 1. * 通用元素选择器,匹配任何元素 2. E 标签选择器,匹配所有使用E标签的元素 3. .info class选择器,匹配所有class属性中包...
一、基本选择器
序号 选择器 含义
1. * 通用元素选择器,匹配任何元素
2. E 标签选择器,匹配所有使用E标签的元素
3. .info class选择器,匹配所有class属性中包含info的元素
4. #footer id选择器,匹配所有id属性等于footer的元素
实例: * { margin:0; padding:0; } p { font-size:2em; } .info { background:#ff0; } p.info { background:#ff0; } p.info.error { color:#900; font-weight:bold; } #info { background:#ff0; } p#info { background:#ff0; } 二、多元素的组合选择器
序号 选择器 含义
5. E,F 多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔
6. E F 后代元素选择器,匹配所有属于E元素后代的F元素,E和F之间用空格分隔
7. E > F 子元素选择器,匹配所有E元素的子元素F
8. E + F 毗邻元素选择器,匹配所有紧随E元素之后的同级元素F
实例: p p { color:#f00; } #nav li { display:inline; } #nav a { font-weight:bold; } p > strong { color:#f00; } p + p { color:#f00; } 三、CSS 2.1 属性选择器
序号 选择器 含义
9. E[att] 匹配所有具有att属性的E元素,不考虑它的值。(注意:E在此处可以省略,比如“[cheacked]”。以下同。)
10. E[att=val] 匹配所有att属性等于“val”的E元素
11. E[att~=val] 匹配所有att属性具有多个空格分隔的值、其中一个值等于“val”的E元素
12. E[att|=val] 匹配所有att属性具有多个连字号分隔(hyphen-separated)的值、其中一个值以“val”开头的E元素,主要用于lang属性,比如“en”、“en-us”、“en-gb”等等
实例: p[title] { color:#f00; } p[class=error] { color:#f00; } td[headers~=col1] { color:#f00; } p[lang|=en] { color:#f00; } blockquote[class=quote][cite] { color:#f00; } 四、CSS 2.1中的伪类
序号 选择器 含义
13. E:first-child 匹配父元素的第一个子元素
14. E:link 匹配所有未被点击的链接
15. E:visited 匹配所有已被点击的链接
16. E:active 匹配鼠标已经其上按下、还没有释放的E元素
17. E:hover 匹配鼠标悬停其上的E元素
18. E:focus 匹配获得当前焦点的E元素
19. E:lang(c) 匹配lang属性等于c的E元素
实例: p:first-child { font-style:italic; } input[type=text]:focus { color:#000; background:#ffe; } input[type=text]:focus:hover { background:#fff; } q:lang(sv) { quotes: ?D ?D ?9 ?9; } 五、 CSS 2.1中的伪元素
序号 选择器 含义
20. E:first-line 匹配E元素的第一行
21. E:first-letter 匹配E元素的第一个字母
22. E:before 在E元素之前插入生成的内容
23. E:after 在E元素之后插入生成的内容
实例: p:first-line { font-weight:bold; color;#600; } .preamble:first-letter { font-size:1.5em; font-weight:bold; } .cbb:before { content:; display:block; height:17px; width:18px; background:url(top.png) no-repeat 0 0; margin:0 0 0 -18px; } a:link:after { content: ( attr(href) ) ; } 六、CSS 3的同级元素通用选择器
序号 选择器 含义
24. E ~ F 匹配任何在E元素之后的同级F元素
实例: p ~ ul { background:#ff0; } 七、CSS 3 属性选择器
序号 选择器 含义
25. E[att^=”val”] 属性att的值以val开头的元素
26. E[att$=”val”] 属性att的值以val结尾的元素
27. E[att*=”val”] 属性att的值包含val字符串的元素
实例: p[id^=nav] { background:#ff0; } 八、CSS 3中与用户界面有关的伪类
序号 选择器 含义
28. E:enabled 匹配表单中激活的元素
29. E:disabled 匹配表单中禁用的元素
30. E:checked 匹配表单中被选中的radio(单选框)或checkbox(复选框)元素
31. E::selection 匹配用户当前选中的元素
实例: input[type=text]:disabled { background:#ddd; } 九、CSS 3中的结构性伪类
序号 选择器 含义
32. E:root 匹配文档的根元素,对于HTML文档,就是HTML元素
33. E:nth-child(n) 匹配其父元素的第n个子元素,第一个编号为1
34. E:nth-last-child(n) 匹配其父元素的倒数第n个子元素,第一个编号为1
35. E:nth-of-type(n) 与:nth-child()作用类似,但是仅匹配使用同种标签的元素
36. E:nth-last-of-type(n) 与:nth-last-child() 作用类似,但是仅匹配使用同种标签的元素
37. E:last-child 匹配父元素的最后一个子元素,等同于:nth-last-child(1)
38. E:first-of-type 匹配父元素下使用同种标签的第一个子元素,等同于:nth-of-type(1)
39. E:last-of-type 匹配父元素下使用同种标签的最后一个子元素,等同于:nth-last-of-type(1)
40. E:only-child 匹配父元素下仅有的一个子元素,等同于:first-child:last-child或 :nth-child(1):nth-last-child(1)
41. E:only-of-type 匹配父元素下使用同种标签的唯一一个子元素,等同于:first-of-type:last-of-type或 :nth-of-type(1):nth-last-of-type(1)
42. E:empty 匹配一个不包含任何子元素的元素,注意,文本节点也被看作子元素
实例: p:nth-child(3) { color:#f00; } p:nth-child(odd) { color:#f00; } p:nth-child(even) { color:#f00; } p:nth-child(3n+0) { color:#f00; } p:nth-child(3n) { color:#f00; } tr:nth-child(2n+11) { background:#ff0; } tr:nth-last-child(2) { background:#ff0; } p:last-child { background:#ff0; } p:only-child { background:#ff0; } p:empty { background:#ff0; } 十、CSS 3的反选伪类
序号 选择器 含义
43. E:not(s) 匹配不符合当前选择器的任何元素
实例: :not(p) { border:1px solid #ccc; } 十一、CSS 3中的 :target 伪类
序号 选择器 含义
44. E:target 匹配文档中特定id点击后的效果

十二、新增选择器

新增选择器列表:

  E[foo^=bar]:匹配foo属性值以bar开始的E元素

  E[foo$=bar]:匹配foo属性值以bar结束的E元素

  E[foo*=bar]:匹配foo属性值包含bar的E元素

  这几个选择器很简单,其实在jQuery的选择器中早就包含了,所以就不多说了。

浏览器兼容性:

CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结
  • IE 6
  • IE 7
  • IE 8
  • IE 9
  • Chrome 1.0.x
  • Chrome 2.0.x
  • Chrome 3.0.x
  • Chrome 4.0.x
  • FireFox 1.5
  • FireFox 2.0
  • FireFox 3.0
  • FireFox 3.5
  • Opera 9.0
  • Opera 9.6
  • Opera 10.0
  • Opera 10.5
  • Safari 3.1
  • Safari 4.0

  连IE7、8都提供了支持,IE6正逐渐被淘汰,所以放心地用吧。

结构伪类选择器

新增结构伪类选择器列表:

  E:root:匹配E所在文档的根元素

  E:nth-child(n):匹配元素类型为E且是父元素的第n个子元素

  E:nth-last-child(n):匹配元素类型为E且是父元素的倒数第n个子元素(与上一项顺序相反)

  E:nth-of-type(n):匹配父元素的第n个类型为E的子元素

  E:nth-last-of-type(n):匹配父元素的倒数第n个类型为E的子元素(与上一项顺序相反)

  E:first-of-type:匹配父元素的第一个类型为E的子元素

  E:last-child:匹配元素类型为E且是父元素的最后一个子元素

  E:last-of-type:匹配父元素的最后一个类型为E的子元素

  E:only-child:匹配元素类型为E且是父元素中唯一的子元素

  E:only-of-type:匹配父元素中唯一子元素是E的子元素

  E:empty:匹配不包含子节点(包括文本)的E元素

  这几个选择器平时用的比较少,其中 -child(n) 跟 -of-type(n) 很容易混淆,下面就以 nth-child(n) 与 nth-of-type(n) 为例,说明一下区别:


P One

P Two

Span Test

P One

P Two

  运行结果如下:

 

  我们可以看到,:nth-child(n) 表示,选择满足以下条件的元素:1、是一个p元素,2. 是父元素的第n个子元素。

  :nth-of-type(n) 表示:选择父元素的第n个子元素p

  不知道大家看到这里明白没,如果还没弄明白请看原文:https://css-tricks.com/the-difference-between-nth-child-and-nth-of-type/

浏览器兼容性

CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结
  • IE 6
  • IE 7
  • IE 8
  • IE 9
  • Chrome 1.0.x
  • Chrome 2.0.x
  • Chrome 3.0.x
  • Chrome 4.0.x
  • FireFox 1.5
  • FireFox 2.0
  • FireFox 3.0
  • FireFox 3.5
  • Opera 9.0
  • Opera 9.6
  • Opera 10.0
  • Opera 10.5
  • Safari 3.1
  • Safari 4.0

  注:FireFox 1.5/2.0/3.0支持E:root,FireFox 3.0支持E:last-child、E:only-child、E:empty。

  由于IE6/7/8不支持,没办法,选择合适的场合用吧。

UI元素状态伪类选择器

新增的UI元素状态伪类选择器列表:

  E:enabled:选择所有可用的E元素

  E:disabled:选择所有不可用的E元素

  E:checked:选择所有选中的E元素(主要用于checkbox和radio-button)

浏览器兼容性

CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结
  • IE 6
  • IE 7
  • IE 8
  • IE 9
  • Chrome 1.0.x
  • Chrome 2.0.x
  • Chrome 3.0.x
  • Chrome 4.0.x
  • FireFox 1.5
  • FireFox 2.0
  • FireFox 3.0
  • FireFox 3.5
  • Opera 9.0
  • Opera 9.6
  • Opera 10.0
  • Opera 10.5
  • Safari 3.1
  • Safari 4.0

  how old are IE6/7/8???

目标伪类选择器

新增目标伪类选择器:

  E:target:匹配URI中锚点指定的元素

  这个有点绕,什么意思呢?例如页面上有个id为test的DIV,然后在URI中有#test的话,就会给id为test的DIV加上定义的样式。

浏览器兼容性

CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结
  • IE 6
  • IE 7
  • IE 8
  • IE 9
  • Chrome 1.0.x
  • Chrome 2.0.x
  • Chrome 3.0.x
  • Chrome 4.0.x
  • FireFox 1.5
  • FireFox 2.0
  • FireFox 3.0
  • FireFox 3.5
  • Opera 9.0
  • Opera 9.6
  • Opera 10.0
  • Opera 10.5
  • Safari 3.1
  • Safari 4.0

  how old are IE6/7/8???

否定伪类选择器

新增否定伪类选择器:

  E:not(s):匹配类型为E,不匹配选择符为 s 的元素。

浏览器兼容性

CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结
  • IE 6
  • IE 7
  • IE 8
  • IE 9
  • Chrome 1.0.x
  • Chrome 2.0.x
  • Chrome 3.0.x
  • Chrome 4.0.x
  • FireFox 1.5
  • FireFox 2.0
  • FireFox 3.0
  • FireFox 3.5
  • Opera 9.0
  • Opera 9.6
  • Opera 10.0
  • Opera 10.5
  • Safari 3.1
  • Safari 4.0

  FireFox现在都已经14+版了,主要还是IE的问题,有选择地用吧。

通用兄弟元素选择器

新增通用兄弟元素选择器

  E~F:匹配位于E元素后面的F元素

  注意,E和F是兄弟元素。

浏览器兼容性

CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结 CSS选择器详细总结
  • IE 6
  • IE 7
  • IE 8
  • IE 9
  • Chrome 1.0.x
  • Chrome 2.0.x
  • Chrome 3.0.x
  • Chrome 4.0.x
  • FireFox 1.5
  • FireFox 2.0
  • FireFox 3.0
  • FireFox 3.5
  • Opera 9.0
  • Opera 9.6
  • Opera 10.0
  • Opera 10.5
  • Safari 3.1
  • Safari 4.0

  兼容性不错,可以大方地使用。

综合示例

  测试代码:





前端工程师要学习的内容主要有:

  1. JavaScript
  2. CSS
  3. HTML
  4. Ajax
  5. JSON
  6. XML
  7. jQuery

ol li:nth-child(3n+1)表示匹配索引(从1开始)为3n+1的li元素,n可取0、1、2、3...等。E:nth-child(n)中n还为odd(奇数)、even(偶数)

 

 

Tags:CS SS S选 选择 
作者:网络 来源:小平果的专栏