CSS学习笔记

CSS选择器


CSS(层叠样式表)提供了多种选择器,用于选择要应用样式的 HTML 元素。

CSS 选择器用于选择你想要的元素的样式的模式。

下列表格中的 "CSS" 列表示在 CSS 版本的属性定义,CSS1、CSS2 和 CSS3 是层叠样式表(Cascading Style Sheets)的不同版本,每个版本引入了新的特性和功能,以改进网页样式的控制和设计。

常见的CSS选择器

下是一些常见的 CSS 选择器:

**元素选择器(Element Selector):**通过元素名称选择 HTML 元素。

如下代码,p 选择器将选择所有

元素:

html 复制代码
p {
  color: blue;
}

**类选择器(Class Selector):**通过类别名称选择具有特定类别的 HTML 元素。

类选择器以 . 开头,后面跟着类别名称。

如下代码,.highlight 选择器将选择所有具有类别为 "highlight" 的元素。

html 复制代码
.highlight {
  background-color: yellow;
}

**ID 选择器(ID Selector):**通过元素的唯一标识符(ID)选择 HTML 元素。

ID 选择器以 # 开头,后面跟着 ID 名称。

如下代码,#runoob 选择器将选择具有 ID 为 "runoob" 的元素。

#runoob {
  width: 200px;
}

**属性选择器(Attribute Selector):**通过元素的属性选择 HTML 元素。属性选择器可以根据属性名和属性值进行选择。

如下代码,input[type="text"] 选择器将选择所有 type 属性为 "text" 的 元素。

input[type="text"] {
  border: 1px solid gray;
}

**后代选择器(Descendant Selector):**通过指定元素的后代关系选择 HTML 元素。

后代选择器使用空格分隔元素名称。

如下代码,div p 选择器将选择所有在
元素内的

元素。

div p {
  font-weight: bold;
}

更多选择器参考下列表格:

编号 选择器 示例 实例说明 CSS
1 .class .intro 选择所有class="intro"的元素 1
2 #id #firstname 选择所有id="firstname"的元素 1
3 * * 选择所有元素 2
4 element p 选择所有 元素 1
5 element,element div,p 选择所有 元素和 元素 1
6 element*.class* p.hometown 选择所有 class="hometown"的 元素 1
7 element element div p 选择 元素内的所有 元素 1
8 element >element div>p 选择所有父级元素是 元素的 元素 2
9 element +element div+p 选择所有紧跟在 元素之后的第一个 元素 2
10 [attribute] [target] 选择所有带有target属性元素 2
11 [attribute =value] [target=-blank] 选择所有使用target="-blank"的元素 2
12 [attribute ~=value] [title~=flower] 选择标题属性包含单词"flower"的所有元素 2
13 [attribute |=language] [lang|=en] 选择 lang 属性等于 en ,或者以 en- 为开头的所有元素 2
14 :link a:link 选择所有未访问链接 1
15 :visited a:visited 选择所有访问过的链接 1
16 :active a:active 选择活动链接 1
17 :hover a:hover 选择鼠标在链接上面时 1
18 :focus input:focus 选择具有焦点的输入元素 2
19 :first-letter p:first-letter 选择每一个 元素的第一个字母 1
20 :first-line p:first-line 选择每一个 元素的第一行 1
21 :first-child p:first-child 指定只有当 元素是其父级的第一个子级的样式。 2
22 :before p:before 在每个 元素之前插入内容 2
23 :after p:after 在每个 元素之后插入内容 2
24 :lang(language) p:lang(it) 选择一个lang属性的起始值="it"的所有 元素 2
25 element1 ~element2 p~ul 选择p元素之后的每一个ul元素 3
26 [attribute ^=value] a[src^="https"] 选择每一个src属性的值以"https"开头的元素 3
27 [attribute $=value] a[src$=".pdf"] 选择每一个src属性的值以".pdf"结尾的元素 3
28 [attribute *=value] a[src*="runoob"] 选择每一个src属性的值包含子字符串"runoob"的元素 3
29 :first-of-type p:first-of-type 选择每个p元素是其父级的第一个p元素 3
30 :last-of-type p:last-of-type 选择每个p元素是其父级的最后一个p元素 3
31 :only-of-type p:only-of-type 选择每个p元素是其父级的唯一p元素 3
32 :only-child p:only-child 选择每个p元素是其父级的唯一子元素 3
33 :nth-child(n) p:nth-child(2) 选择每个p元素是其父级的第二个子元素 3
34 :nth-last-child(n) p:nth-last-child(2) 选择每个p元素的是其父级的第二个子元素,从最后一个子项计数 3
35 :nth-of-type(n) p:nth-of-type(2) 选择每个p元素是其父级的第二个p元素 3
36 :nth-last-of-type(n) p:nth-last-of-type(2) 选择每个p元素的是其父级的第二个p元素,从最后一个子项计数 3
37 :last-child p:last-child 选择每个p元素是其父级的最后一个子级。 3
38 :root :root 选择文档的根元素 3
39 :empty p:empty 选择每个没有任何子级的p元素(包括文本节点) 3
40 :target #news:target 选择当前活动的#news元素(包含该锚名称的点击的URL) 3
41 :enabled input:enabled 选择每一个已启用的输入元素 3
42 :disabled input:disabled 选择每一个禁用的输入元素 3
43 :checked input:checked 选择每个选中的输入元素 3
44 :not(selector) :not§ 选择每个并非p元素的元素 3
45 ::selection ::selection 匹配元素中被用户选中或处于高亮状态的部分 3
46 :out-of-range :out-of-range 匹配值在指定区间之外的input元素 3
47 :in-range :in-range 匹配值在指定区间之内的input元素 3
48 :read-write :read-write 用于匹配可读及可写的元素 3
49 :read-only :read-only 用于匹配设置 "readonly"(只读) 属性的元素 3
50 :optional :optional 用于匹配可选的输入元素 3
51 :optional :optional 用于匹配可选的输入元素 3
52 :valid :valid 用于匹配输入值为合法的元素 3
53 :invalid :invalid 用于匹配输入值为非法的元素 3
相关推荐
小码的头发丝、8 分钟前
Java进阶学习笔记|面向对象
java·笔记·学习
坊钰39 分钟前
【Java 数据结构】移除链表元素
java·开发语言·数据结构·学习·链表
Purple Coder1 小时前
第6章 图论
笔记
阿七想学习1 小时前
数据结构《排序》
java·数据结构·学习·算法·排序算法
前端Hardy2 小时前
HTML&CSS:惊!3D 折叠按钮
css·3d·html
胡西风_foxww2 小时前
【ES6复习笔记】数值扩展(16)
前端·笔记·es6·扩展·数值
Somnus陳3 小时前
软考架构师笔记-计算机系统组成-1
笔记·系统架构
潜意识起点4 小时前
精通 CSS 阴影效果:从基础到高级应用
前端·css
LuH11244 小时前
【论文阅读笔记】IC-Light
论文阅读·笔记
汤姆和佩琦4 小时前
2024-12-25-sklearn学习(20)无监督学习-双聚类 料峭春风吹酒醒,微冷,山头斜照却相迎。
学习·聚类·sklearn