Home >Web Front-end >HTML Tutorial >CSS Selector Notes_html/css_WEB-ITnose

CSS Selector Notes_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-24 11:46:35994browse

Author: Ruan Yifeng

Date: March 12, 2009

When I was learning jQuery last year, I made some selectors ( selector) notes.

I took it out and looked at it in the past few days and found that I had forgotten a lot of it. So, I decided to post them here for easy reference later. This should also be useful to other friends. After all, the selector is the first step in creating web page effects.

The notes are divided into two parts. Today is the CSS selector, and there will be a part of xPath selector in the future. Today's notes include 44 selectors, basically covering all the provisions of CSS 2 and CSS 3.

=====================

CSS Selector Notes

Compiled by Ruan Yifeng

Reference URL: 456 Berea Street

1. Basic selector

序号 选择器 含义
1. * 通用元素选择器,匹配任何元素
2. E 标签选择器,匹配所有使用E标签的元素
3. .info class选择器,匹配所有class属性中包含info的元素
4. #footer id选择器,匹配所有id属性等于footer的元素

Example:

* { 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; }

2. Multi-element combination selector

序号 选择器 含义
5. E,F 多元素选择器,同时匹配所有E元素或F元素,E和F之间用逗号分隔
6. E F 后代元素选择器,匹配所有属于E元素后代的F元素,E和F之间用空格分隔
7. E > F 子元素选择器,匹配所有E元素的子元素F
8. E F 毗邻元素选择器,匹配所有紧随E元素之后的同级元素F

Example:

div p { color: #f00; }

#nav li { display:inline; }

#nav a { font-weight:bold; }

div > strong { color:#f00; }

p p { color:#f00; }

3. CSS 2.1 attribute selector

序号 选择器 含义
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"等等

Example:

p[title] { color:#f00; }

div[class=error] { color:#f00; }

td[headers~=col1] { color:#f00; }

p[lang|=en] { color:#f00; }

blockquote[class=quote][cite] { color:#f00; }

4. CSS Pseudo class

序号 选择器 含义
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元素
in 2.1

Example:

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: "201D" "201D" "2019" "2019"; }

5. Pseudo-elements in CSS 2.1

序号 选择器 含义
20. E:first-line 匹配E元素的第一行
21. E:first-letter 匹配E元素的第一个字母
22. E:before 在E元素之前插入生成的内容
23. E:after 在E元素之后插入生成的内容

Example:

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) ") "; }

6. CSS 3 universal selector for sibling elements

序号 选择器 含义
24. E ~ F 匹配任何在E元素之后的同级F元素

Example:

p ~ ul { background:#ff0; }

7. CSS 3 attribute selector

序号 选择器 含义
25. E[att^="val"] 属性att的值以"val"开头的元素
26. E[att$="val"] 属性att的值以"val"结尾的元素
27. E[att*="val"] 属性att的值包含"val"字符串的元素

Example:

div[id^="nav"] { background:#ff0; }

8. Pseudo classes related to user interface in CSS 3

序号 选择器 含义
28. E:enabled 匹配表单中激活的元素
29. E:disabled 匹配表单中禁用的元素
30. E:checked 匹配表单中被选中的radio(单选框)或checkbox(复选框)元素
31. E::selection 匹配用户当前选中的元素

Example:

input[type="text"]:disabled { background:#ddd; }

9. Structural pseudo-classes in 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 匹配一个不包含任何子元素的元素,注意,文本节点也被看作子元素

Example:

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; }

10. CSS 3 anti-selection pseudo-class

序号 选择器 含义
43. E:not(s) 匹配不符合当前选择器的任何元素

Example:

:not(p) { border:1px solid #ccc; }

11. :target pseudo-class in CSS 3

序号 选择器 含义
44. E:target 匹配文档中特定"id"点击后的效果

Please refer to HTML Detailed explanation and examples of this selector on DOG.

(End)

Statement:
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn