CSS教程(二)- CSS选择器
1. 作用
- 匹配文档中的某些元素为其应用样式。
- 根据不同需求把不同的标签选出来。
2. 分类
- 分类
- 基础选择器
- 包含 标签选择器、ID选择器、类选择器、通用选择器等
- 复合选择器
- 包含 后代选择器、子代选择器、伪类选择器等
- 包含 后代选择器、子代选择器、伪类选择器等
- 基础选择器
1 标签选择器
-
介绍
- 又称为元素选择器,根据标签名匹配文档中所有该元素,为页面中某一类标签指定统一的CSS样式。
-
语法
标签名{属性1: 属性值1;属性2: 属性值2;... }

-
示例

-
说明
- 选择器:指需设置样式的 HTML 元素。
- 声明块包含一条或多条用分号分隔的声明。
- 每条声明都包含一个 CSS 属性名称和一个值,以冒号分隔。
- 多条 CSS 声明用分号分隔,声明块用花括号括起来。
-
优点
- 能快速为页面中同类型的标签统一设置样式。
-
缺点
- 不能设计差异化样式,只能选择全部的当前标签。
2 ID选择器
-
介绍
- 根据元素的 id 属性值匹配文档中唯一的元素,id具有唯一性,不能重复使用。
- 在 CSS 中 ID选择器以 # 来定义
-
语法
#id属性值{属性1: 属性值1;属性2: 属性值2;...} -
示例

-
注意
- id属性值自定义,可以由数字、字母、下划线、- 组成,不能以数字开头;
- 尽量见名知意,多个单词组成时,可以使用连接符,下划线,小驼峰表示。
-
口诀
- 样式#定义,结构id调用,只能调用一次
- 样式#定义,结构id调用,只能调用一次
3 类选择器
-
介绍
-
想要差异化选择不同的标签,单独选一个或者某几个标签,可以使用类选择器。
- 根据元素的class属性值匹配相应的元素,class属性值可以重复使用,实现样式的复用(简言之:用于查找或选取要设置样式的 HTML元素)
-
语法
.类名 {属性1: 属性值1;属性2: 属性值2;... } -
示例

-
说明
- 长名称或词组可以使用中横线来为选择器命名。
- 不要使用纯数字、中文等命名,尽量使用英文字母来表示。
- 命名要有意义,尽量使别人一眼就知道这个类名的目的。
-
口诀
- 样式点定义,结构类调用
-
特殊用法
-
类选择器与其他选择器结合使用
a.c1{ }- 注意:标签与类选择器结合时,标签在前,类选择器在后
-
class属性值可以写多个(多个类名之间必必须用 空格 分开),共同应用类选择器的样式
<p class="c1 c2"></p>
-
-
示例

4 通用选择器
-
介绍
- 通配符选择器使用 * 定义,它表示选取页面中所有元素(标签)。
-
语法
* {属性1: 属性值1;属性2: 属性值2;... } -
说明
-
通常在最开始对页面设置内边距与外边距的设置(默认body与页面会存在边距)。
*{padding: 0;margin: 0; }
-
-
示例

5 群组选择器
-
介绍
- 也称为并集选择器,可以使用多个不同的选择器为一组元素统一设置样式。
-
语法
selector1,selector2,selector3{ 属性1: 属性值1;属性2: 属性值2;... } -
示例

6 后代选择器
-
介绍
- 匹配满足选择器的所有后代元素(包含直接子元素和间接子元素)
-
语法
selector1 selector2{属性1: 属性值1;属性2: 属性值2;... } -
说明
- 匹配selector1中所有满足selector2的后代元素
- selector1 与 selector2 可以是任意的基础选择器
-
示例

7 子代选择器
-
介绍
- 匹配满足选择器的所有直接子元素,只能选择作为某元素的最近一级子元素
-
语法
selector1>selector2{属性1: 属性值1;属性2: 属性值2;... } -
说明
- selector2 必须是 selector1 的亲子元素
-
示例

8 伪类选择器
-
介绍
- 为元素的不同状态分别设置样式,必须与基础选择器结合使用。
-
特点
用冒号(:)表示,如::hover、:first-child、:last_child
1、链接伪类选择器
-
分类
:link 超链接访问前的状态 :visited 超链接访问后的状态 :hover 鼠标滑过时的状态 :active 鼠标点按不抬起时的状态(激活) -
示例

-
注意
-
超链接如果需要为四种状态分别设置样式,则按照以下顺序【LVHA】声明
:link :visited :hover :active -
超链接常用设置 :
a{/*统一设置超链接默认样式(不分状态)*/ }a:hover{/*鼠标滑过时改样式*/ }
-
2、焦点伪类选择器
-
:focus
- 用于选取获得焦点的表单元素。
- 一般情况 <input> 类表单元素才能获取
-
示例

3、结构伪类选择器
-
作用
- 根据元素的
结构关系查找元素
- 根据元素的
-
选择器
选择器 说明 E:first-child 查找第1个E元素 E:last-child 查找最后一个E元素 E:nth-child(N) 查找第N个E元素(第1个元素N值为1) -
:nth-child(公式)
-
作用:根据元素的关系结构
查找多个元素。公式 功能 2n 偶数标签 2n+1; 2n-1 奇数标签 5n 找到5的倍数的标签 n+5 找到第5个以后的标签 -n+5 找到第5个以前的标签
-
-
示例

4、伪元素选择器
-
作用
- 创建
虚拟元素(伪元素),用来摆放装饰性的内容
- 创建
-
选择器
选择器 说明 E::before 在E元素里面最前面添加一个伪元素 E::after 在E元素里面最后面添加一个伪元素 -
注意
- 必须设置 content: “” 属性,用来设置
伪元素的内容,如果无内容,则引号留白即可 - 微元素必须是
行内显示模式 权重和标签选择器相同。
- 必须设置 content: “” 属性,用来设置
-
应用场景
- 插入内容:使用::before和::after伪元素在元素的前后插入内容,如在段落前添加引用符号、图标装饰等
- 分割符号:使用::before和::after伪元素在列表项之间添加分割线或其他符号,提高列表的可读性
- 清除浮动:使用::after伪元素来清除浮动,保证容器正确包裹元素
- 首行缩进:使用::first-line伪元素来设置元素内第一行的样式,如字体、颜色等
- 首字母样式:使用::first-letter伪元素来设置元素内第一个字母的样式,如字体大小、颜色等
-
示例

- 总结

相关文章:
CSS教程(二)- CSS选择器
1. 作用 匹配文档中的某些元素为其应用样式。根据不同需求把不同的标签选出来。 2. 分类 分类 基础选择器 包含 标签选择器、ID选择器、类选择器、通用选择器等 复合选择器 包含 后代选择器、子代选择器、伪类选择器等 1 标签选择器 介绍 又称为元素选择器,根…...
Ubuntu20.04 解决一段时间后键盘卡死 输入延迟很大的问题 ubuntu
Ubuntu20.04 解决一段时间后键盘卡死 输入延迟很大的问题 为了确保您能顺利通过双击快捷方式来重启 IBus,下面详细描述了从脚本创建到快捷方式设置的每一步,包括具体的命令行操作和必要的说明,以确保您能够按步骤成功执行。 步骤 1: 创建并…...
http(s)接口设计注意事项
http(s)在设计时应考虑: 一、签名认证 鉴权,如jwt方式等。 二、重要参数加密 如:用户的登录密码、银行卡号、转账金额、用户身份证等。 三、IP白名单 为了进一步加强API接口的安全性,防止接口的签名或者加密被破解了&#x…...
Font Awesome Web 应用图标
Font Awesome Web 应用图标 引言 在当今的数字时代,图标在Web应用中扮演着至关重要的角色。它们不仅增强了用户界面的视觉吸引力,而且还提高了用户体验和互动性。Font Awesome是一个广受欢迎的图标库,它为开发人员提供了一系列高质量的图标,可以轻松地集成到Web应用中。本…...
bridge-vlan
# 1.topo # 2.创建命名空间 ip netns add ns0 ip netns add ns1 ip netns add ns2 ip netns add ns3 # 3.创建veth设备 ip link add ns0-veth0 type veth peer name hn0-veth0 ip link add ns1-veth0 type veth peer name hn1-veth0 ip link add ns2-veth0 type veth pe…...
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
MySQL与Oracle一样都是通过逻辑存储结构来管理物理存储结构,即管理硬盘上存储的各种文件。下面将详细介绍InnoDB存储引擎中的数据文件和重做日志文件。 一、数据文件 “.ibd”文件和ibdata文件 这两种文件都是存放Innodb数据的文件,之所以有两种文件来…...
华为云前台展示公网访问需要购买EIP,EIP流量走向
华为云前台网络(VPC,安全组,EIP) 1.EIP网段是从哪里划分的? 管理员在后台Service_OM已设置 Service_OM-网络资源-外部网络-创建外部网络基本信息:配置参数:*名称 public*网络类型 LOCAL 不带标签 类似开…...
排序算法 -插入排序
文章目录 1.插入排序(Insertion Sort)1.1 简介1.2 插入排序的步骤1.3 插入排序的C实现1.4 插入排序的时间复杂度1.5 插入排序的空间复杂度1.6 插入排序的动画 2. 二分插入排序(Binary Insertion Sort)2.1 简介2.2 二分插入排序步骤…...
如何使用.bat实现电脑自动重启?
1、在电脑桌面新建一个记事本文档,将如下内容写进去: echo off shutdown /r /t 02、然后,保存一下,再把桌面此文件重命名为电脑重启.bat 3、双击此程序,可以立刻重启电脑。 PS:① 此程序会不保存任何当前…...
使用VSCode远程连接服务器并解决Neo4j无法登陆问题
摘要:本文介绍了如何通过VSCode连接内网部署的Neo4j服务器,并启动服务。在访问Neo4j登录界面时,遇到了端口映射问题导致无法登录。通过手动添加7687端口的映射后,成功登录Neo4j。 我在内网部署了一台服务器,并在其上运…...
使用React和Vite构建一个AirBnb Experiences克隆网站
这一篇文章中,我会教你如何做一个AirBnb Experiences的克隆网站。主要涵盖React中Props的使用。 克隆网站最终呈现的效果: 1. 使用vite构建基础框架 npm create vitelatestcd airbnb-project npm install npm run dev2. 构建网站的3个部分 网站从上…...
HBase压测 ycsb
## ycsb 导入数据 rootXX.14.40.1971、对portrait压测 ansible hadoop -i hosts_hbase_portrait_20230730.txt -m shell -a "hostname && chdir/data/workspace/ycsb-0.17.0 nohup bin/ycsb load hbase20 -P workloads/workload_insert -cp /usr/local/fqlhadoop/…...
基于Python+Django+Vue3+MySQL实现的前后端分类的商场车辆管理系统
项目名称:基于PythonDjangoVue3MySQL实现的前后端分离商场车辆管理系统 技术栈 开发工具:PyCharm、Visual Studio Code (VSCode)运行环境:Python 3.10、MySQL 8.0、Node.js 18技术框架:Django 5、Vue 3.4、Ant-Design-Vue 4.12 …...
网络安全web基础_HTML基础(扫盲篇)
web基础_HTML扫盲篇 一、什么是 HTML? 二、HTML 的基本特点 三、HTML 基本结构概述 1.文档声明(!DOCTYPE html) 2. html元素 3. head元素 4. body 元素 四、HTML5的主要标签清单 文档结构标签 文本内容标签 链接和锚点标签 表格标…...
(附项目源码)Java开发语言,监督管家APP的设计与实现 58,计算机毕设程序开发+文案(LW+PPT)
摘要 随着互联网的快速发展和智能手机的普及,越来越多的用户选择通过移动应用程序进行事项设定、提醒通知和事项打卡。监督管家APP作为一个专注于事项设定、提醒通知、事项打卡的监督管理平台,具有广泛的应用前景和商业价值。本研究旨在构建一个功能丰富…...
前端基础的讲解-JS(11)
对象 对象是什么? 在 JavaScript 中,对象是一组无序的相关属性和方法的集合,所有的事物都是对象,所有的数据类型都可以存放在内。 属性:即事物的特征,在对象中用属性来表示(常用名词…...
Python魔法方法深度解析:解密__call__、__new__和__del__的核心奥义
解锁Python编程的无限可能:《奇妙的Python》带你漫游代码世界 《Python OpenCV从菜鸟到高手》带你进入图像处理与计算机视觉的大门! Python中的魔法方法(Magic Methods)是构建Python高级功能的基础,它们使得对象可以…...
当微软windows的记事本被AI加持
1985年,微软发布了Windows 1.0,推出了一款革命性的产品:记事本(Notepad)。这款软件旨在鼓励使用一种未来主义的新设备——鼠标,并让人们可以不依赖VI等键盘工具就能书写文本和编写代码。记事本因其简洁和高…...
Python酷库之旅-第三方库Pandas(213)
目录 一、用法精讲 996、pandas.DatetimeIndex.day属性 996-1、语法 996-2、参数 996-3、功能 996-4、返回值 996-5、说明 996-6、用法 996-6-1、数据准备 996-6-2、代码示例 996-6-3、结果输出 997、pandas.DatetimeIndex.hour属性 997-1、语法 997-2、参数 99…...
普林斯顿:LLM基于边际优化的梯度纠缠
📖标题:A Common Pitfall of Margin-based Language Model Alignment: Gradient Entanglement 🌐来源:arXiv, 2410.13828 🌟摘要 🔸从人类反馈中强化学习(RLHF)已成为对齐语言模型…...
Admin.Net中的消息通信SignalR解释
定义集线器接口 IOnlineUserHub public interface IOnlineUserHub {/// 在线用户列表Task OnlineUserList(OnlineUserList context);/// 强制下线Task ForceOffline(object context);/// 发布站内消息Task PublicNotice(SysNotice context);/// 接收消息Task ReceiveMessage(…...
《Playwright:微软的自动化测试工具详解》
Playwright 简介:声明内容来自网络,将内容拼接整理出来的文档 Playwright 是微软开发的自动化测试工具,支持 Chrome、Firefox、Safari 等主流浏览器,提供多语言 API(Python、JavaScript、Java、.NET)。它的特点包括&a…...
UDP(Echoserver)
网络命令 Ping 命令 检测网络是否连通 使用方法: ping -c 次数 网址ping -c 3 www.baidu.comnetstat 命令 netstat 是一个用来查看网络状态的重要工具. 语法:netstat [选项] 功能:查看网络状态 常用选项: n 拒绝显示别名&#…...
ElasticSearch搜索引擎之倒排索引及其底层算法
文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...
HDFS分布式存储 zookeeper
hadoop介绍 狭义上hadoop是指apache的一款开源软件 用java语言实现开源框架,允许使用简单的变成模型跨计算机对大型集群进行分布式处理(1.海量的数据存储 2.海量数据的计算)Hadoop核心组件 hdfs(分布式文件存储系统)&a…...
基于SpringBoot在线拍卖系统的设计和实现
摘 要 随着社会的发展,社会的各行各业都在利用信息化时代的优势。计算机的优势和普及使得各种信息系统的开发成为必需。 在线拍卖系统,主要的模块包括管理员;首页、个人中心、用户管理、商品类型管理、拍卖商品管理、历史竞拍管理、竞拍订单…...
毫米波雷达基础理论(3D+4D)
3D、4D毫米波雷达基础知识及厂商选型 PreView : https://mp.weixin.qq.com/s/bQkju4r6med7I3TBGJI_bQ 1. FMCW毫米波雷达基础知识 主要参考博文: 一文入门汽车毫米波雷达基本原理 :https://mp.weixin.qq.com/s/_EN7A5lKcz2Eh8dLnjE19w 毫米波雷达基础…...
【无标题】湖北理元理律师事务所:债务优化中的生活保障与法律平衡之道
文/法律实务观察组 在债务重组领域,专业机构的核心价值不仅在于减轻债务数字,更在于帮助债务人在履行义务的同时维持基本生活尊严。湖北理元理律师事务所的服务实践表明,合法债务优化需同步实现三重平衡: 法律刚性(债…...
【1】跨越技术栈鸿沟:字节跳动开源TRAE AI编程IDE的实战体验
2024年初,人工智能编程工具领域发生了一次静默的变革。当字节跳动宣布退出其TRAE项目(一款融合大型语言模型能力的云端AI编程IDE)时,技术社区曾短暂叹息。然而这一退场并非终点——通过开源社区的接力,TRAE在WayToAGI等…...
前端工具库lodash与lodash-es区别详解
lodash 和 lodash-es 是同一工具库的两个不同版本,核心功能完全一致,主要区别在于模块化格式和优化方式,适合不同的开发环境。以下是详细对比: 1. 模块化格式 lodash 使用 CommonJS 模块格式(require/module.exports&a…...
