CSS 选择器

CSS 引入方式

CSS 有三种引入方式,第一种为内部样式表,此方式仅学习使用

<html>
    <head>
        <title></title>
        <style>
        	/* 此处写 CSS */
        </style>
    </head>
    <body>
    </body>
</html>

第二种为行内样式,一般配合 JavaScript 使用

<div style="此处写 CSS"></div>

最后一种为外部样式表,将 CSS 代码写在单独文件,通过 link 标签引入,开发时常用

<head>
    <title></title>
    <link rel="stylesheet" href="css path" />
</head>

CSS 选择器

选择器的作用是查找标签,设置样式,一共四种基础选择器

标签选择器

直接使用标签名作为选择器,即选中同名标签设置相同的样式

<html>
    <head>
        <title></title>
        <style>
            div{
                /* 选中所以 div 标签设置样式 */
            }
        </style>
    </head>
    <body>
        <div></div>
    </body>
</html>

可以使用的标签有 p、h1、div、a、img 等

类选择器

用于查找标签,差异化设置标签的显示效果

<html>
    <head>
        <title></title>
        <style>
            .first{
                /* 选中 first div 设置样式 */
            }
        </style>
    </head>
    <body>
        <div class="first">
            first div
        </div>
        <div>
            second div
        </div>
    </body>
</html>

类名若是多个单词可用 - 连接,一个类选择器可用供多个标签使用,一个标签可以使用多个类名

<div class="first second">
    使用了两个类名
</div>

id 选择器

用于查找标签,差异化设置标签的显示效果,一般配合 JavaScript 使用

<html>
    <head>
        <title></title>
        <style>
            #app{
                /* 选中 id 为 app 的标签 */
            }
        </style>
    </head>
    <body>
        <div id="app"></div>
        <div></div>
    </body>
</html>

同一个 id 选择器在一个页面只能使用一次

通配符选择器

查找页面所有标签,设置相同样式,一般用于清除标签的默认样式

<style>
    *{
        /* 书写样式影响所有标签 */
    }
</style>

复合选择器

定义:由两个或多个基础选择器,通过不同的方式组合而成

作用:更准确、更高效的选择目标元素 (标签)

后代选择器

可以选中某元素的所有后代元素

语法:父选择器 子选择器 { CSS 属性 }

父选择器与子选择器之间用空格隔开,可以为类选择器或 id 选择器

<style>
    div span{
        color: aqua;
    }
</style>

<span>颜色不会变</span>
<div>
    <span>颜色会变</span>
    <p>
        <span>颜色会变</span>
    </p>
</div>

子代选择器

只选中某元素子级元素

语法:父选择器 > 子选择器 { CSS 属性 }

<style>
    div > span{
        color: aqua;
    }
</style>

<div>
    <span>颜色会变</span>
    <p>
        <span>颜色不会变</span>
    </p>
</div>

并集选择器

选中多组标签设置相同的样式

语法:选择器1, 选择器2, ..., 选择器N { CSS 属性 }

<style>
    div, span, p {
        color: aqua;
    }
</style>

<div>颜色会变</div>
<p>颜色会变</p>
<span>颜色会变</span>

交集选择器

选中同时满足多个条件的元素

语法:选择器1选择器2 { CSS 属性 } 选择器之间连写,没有任何符号

如果交集选择器中有标签选择器,标签选择器必须书写在最前面

<style>
    p.box {
        color: aqua;
    }
</style>

<p class="box">颜色会变</p>
<p>p 标签,颜色不会变</p>
<div class="box">颜色不会变</div>

伪类选择器

伪类表示元素状态,选中元素的某个状态设置样式

鼠标悬停状态

语法:选择器:hover { CSS 属性 }

<style>
    a:hover{
        color: red;
    }
    .box:hover{
        color: aqua;
    }
</style>

<a href="https://yexca.net">yexca</a>
<div class="box">
    div 标签
</div>

任何标签都可以设置鼠标悬停的状态

超链接的状态

选择器 作用
:link 访问前
:visited 访问后
:hover 鼠标悬停
:active 点击时 (激活)

若给超链接设置四个状态,需按顺序书写

<style>
    a:link {
        color: green;
    }
    a:visited {
        color: red;
    }
    a: hover {
        color: aqua;
    }
    a: active {
        color: orange;
    }
</style>

<a href="#">a 标签</a>

结构伪类选择器

作用:根据元素的结构关系查找元素

选择器 说明
E:first-child 选择第一个 E 元素
E:last-child 选择最后一个 E 元素
E:nth-child(N) 选择第 N 个 E 元素 (从 1 开始)
<style>
	li:first-child {
		background-color: aqua;
	}
	li:last-child {
		background-color: green;
	}
	li:nth-child(3) {
		background-color: blue;
	}
</style>

<ol>
	<li>aqua</li>
	<li>2</li>
	<li>blue</li>
	<li>4</li>
	<li>green</li>
</ol>

其中第三个选择器可以使用公式选择多个元素

功能 公式
偶数个标签 2n
奇数个标签 2n+1 或 2n-1
找到 5 的倍数的标签 5n
找到第 5 个以后的标签 (包括 5) n+5
找到第 5 个以前的标签 (包括 5) -n+5

伪元素选择器

作用:创建虚拟元素 (伪元素),用来摆放装饰性的内容

选择器 说明
E::before 在 E 元素里面最前面添加一个伪元素
E::after 在 E 元素里面最后面添加一个伪元素

注意:

  • 必须设置 content 属性,用来设置伪元素的内容,如果没有内容,则引号留空
  • 伪元素默认为行内显示模式
  • 优先级和标签选择器相同
<style>
	div {
		width: 110px;
		height: 30px;
		background-color: aqua;
		font-size: 20px;
	}
	div::before {
		content: 'yexca';
	}
	div::after {
		content: 'blog';
	}
</style>

<div>'</div>
<!-- 内容为 yexca'blog -->
This post is licensed under CC BY-NC-SA 4.0 by the author.