📜  css 选择器无属性 - CSS (1)

📅  最后修改于: 2023-12-03 15:14:22.679000             🧑  作者: Mango

CSS选择器无属性

CSS选择器是一种用于定位HTML或XML文档中元素的语法。选择器可以根据元素的标签名、属性、关系和伪类等进行定位。本文将重点介绍CSS选择器中的无属性选择器。

1.基本选择器

CSS中的基本选择器包括元素选择器、ID选择器和类选择器。它们是选择器中最为基础的几种类型。

1.1 元素选择器

元素选择器是CSS中最为简单的选择器类型,它通过元素的名称来选择元素。比如:

h1 { color: red; }

上述代码会将HTML中所有的<h1>元素的颜色设为红色。

1.2 ID选择器

ID选择器是根据元素的ID属性来选择元素,它使用#符号表示。比如:

#header { color: blue; }

上述代码会将HTML中ID为"header"的元素的颜色设为蓝色。

1.3 类选择器

类选择器是根据元素的class属性来选择元素,它使用.符号表示。比如:

.warning { color: orange; }

上述代码会将HTML中class为"warning"的元素的颜色设为橙色。

2.组合选择器

组合选择器是指将多种选择器组合在一起来选择元素。组合选择器包括后代选择器、子元素选择器、相邻兄弟选择器和通用兄弟选择器。

2.1 后代选择器

后代选择器用于选择某个元素的后代元素。它使用空格符表示。比如:

nav ul li { font-size: 16px; }

上述代码会将HTML中所有在<nav>标签内的<ul>标签内的<li>标签的字体大小设为16px。

2.2 子元素选择器

子元素选择器用于选择某个元素的子元素。它使用>符号表示。比如:

nav > ul { margin: 0; }

上述代码会将HTML中所有在<nav>标签内的直接子元素<ul>的外边距设为0。

2.3 相邻兄弟选择器

相邻兄弟选择器用于选择某个元素之后紧跟的相邻元素。它使用+符号表示。比如:

h3 + p { font-weight: bold; }

上述代码会将HTML中与<h3>标签相邻的<p>标签的字体加粗。

2.4 通用兄弟选择器

通用兄弟选择器用于选择某个元素之后的所有兄弟元素。它使用~符号表示。比如:

h3 ~ p { font-style: italic; }

上述代码会将HTML中与<h3>标签之后的所有<p>标签的字体设置为斜体。

3.属性选择器

属性选择器是根据元素的属性来选择元素。属性选择器包括存在和值匹配两种类型。

3.1 存在选择器

存在选择器用于选择具有指定属性的元素,与属性值无关。它使用[]括起来,括号中包含要选择的属性名。比如:

a[title] { color: brown; }

上述代码会将HTML中所有带有title属性的链接的颜色设为棕色。

3.2 值匹配选择器

值匹配选择器用于选择具有指定属性并且属性值匹配的元素。它使用[]括起来,括号中包含要选择的属性名和属性值。比如:

a[href="https://www.baidu.com"] { font-weight: bold; }

上述代码会将HTML中所有链接的字体加粗,当且仅当链接地址为"https://www.baidu.com"。

4.伪类选择器

伪类选择器是根据元素的状态或位置等来选择元素。伪类选择器前面需要使用冒号:来标记。

4.1 链接伪类

链接伪类用于选择链接的不同状态,比如未访问链接、访问链接、悬停在链接上时的链接等。

a:link { color: blue; }
a:visited { color: purple; }
a:hover { color: red; }
a:active { color: green; }

上述代码会将HTML中所有未访问链接的颜色设为蓝色,访问链接的颜色设为紫色,鼠标悬停在链接上时的颜色设为红色,点击链接时的颜色设为绿色。

4.2 用户动作伪类

用户动作伪类用于选择当用户执行某个操作时的元素状态,比如鼠标单击、鼠标悬停等。

button:focus { outline: none; }
input:active { background-color: gray; }

上述代码会将HTML中所有button元素获取焦点时的边框设置为无,鼠标点击input元素时背景色设置为灰色。

4.3 结构伪类

结构伪类用于选择文档中某些结构的元素,比如第一个元素、最后一个元素等。

li:first-child { font-weight: bold; }
li:last-child { font-style: italic; }

上述代码会将HTML中所有列表中的第一个元素的字体加粗,最后一个元素的字体设置为斜体。

4.4 平假类

平假类用于选择一个或多个特定的元素,以实现一些特定的效果,如选中第n个元素或其中偶数/奇数元素等。

ul li:nth-child(2n) { background-color: gray; }
ul li:nth-child(odd) { color: blue; }

上述代码会将HTML中所有列表中偶数元素的背景颜色设置为灰色,奇数元素的字体颜色设置为蓝色。

5.无属性选择器

无属性选择器是指没有任何属性限制的选择器,即不根据元素名称、ID、class、属性、关系或伪类来选择元素。CSS中有两个无属性选择器:通配选择器和根选择器。

5.1 通配选择器

通配选择器用于选择文档中的所有元素。它使用*符号表示。

* { margin: 0; padding: 0; }

上述代码会将HTML中所有元素的外边距和内边距都设置为0。

5.2 根选择器

根选择器用于选择文档的根元素,即<html>元素。它使用html符号表示。

html { font-size: 16px; }

上述代码会将HTML文档中的根元素的字体大小设置为16px。

总结

本文介绍了CSS选择器中的无属性选择器的各种类型,包括基本选择器、组合选择器、属性选择器和伪类选择器。通过学习这些选择器的用法,可以更加灵活地定位和控制文档中的各种元素。