目录

  • 基础选择器
  • 组合器
  • 伪类选择器
  • 属性选择器

选择器可以选中页面上的特定元素并为其指定样式。
CSS有多种选择器。

基础选择器

  • 标签选择器 – tagname:匹配目标元素的标签名。优先级是0,0,1。如:p、h1、div
  • 类选择器 – .class:匹配class属性中有指定类名的元素。优先级是0,1,0。如:.media、.menu
  • ID选择器 – #id:匹配拥有指定ID属性的元素。优先级是1,0,0。如:#container
  • 通用选择器 – *:匹配所有元素。优先级是0,0,0。

组合器

组合器是将多个基础选择器连接起来组成一个复杂选择器。

  • 后代组合器:两个基础选择器之间的空格,最常见的组合器。如 .nav-menu li
  • 子组合器(>):匹配的目标元素是其他元素的直接后代。如 .parent > .child
  • 相邻兄弟组合器(+):匹配的目标元素紧跟在其他元素后面。如 p + h2
  • 通用兄弟组合器(~):匹配所有跟随在指定元素之后的兄弟元素。注意,它不会选中目标元素之前的兄弟元素。如 li.active ~ li
  • 复合选择器:多个基础选择器可以连起来组成一个复合选择器。如 h1.page-header。注意:复合选择器选中的元素将匹配其全部基础选择器。例如,.dropdown.is-active能够选中

伪类选择器

伪类选择器用于选中处于某个特定状态的元素。可能是由于用户交互,也可能是由于元素相对于其父级或兄弟元素的位置。伪类选择器始终以一个冒号(:)开始。优先级等于一个类选择器(0,1,0)。

  • :first-child – 匹配的元素是其父元素的第一个子元素。

  • :last-child – 匹配的元素是其父元素的最后一个子元素。

  • :nth-child(an+b) – 匹配的元素在兄弟元素中间有特定的位置。

  • :nth-last-child(an+b) – 类似于:nth-child(),但不是从第一个元素往后数,而是从最后一个元素往前数。

  • :first-of-type – 类似于:first-child,但不是根据在全部子元素中的位置查找元素,而是根据拥有相同标签名的子元素中的数字顺序查找第一个元素。

  • :last-of-type – 匹配每种类型的最后一个子元素。

  • nth-last-of-type(an+b) – 根据元素类型以及特定公式选择元素,从其中最后一个元素往前算,类似于:nth-last-child。

  • :not() – 匹配的元素不匹配括号内的选择器。括号内的选择器必须是基础选择器,它只能指定元素本身,无法用于排除祖先元素,同时不允许包含另一个排除选择器。

  • :focus – 匹配通过鼠标点击、触摸屏幕或者按Tab键导航而获得焦点的元素。

  • :hover – 匹配鼠标指针正悬停在其上方的元素。

  • :root – 匹配文档根元素。对HTML来说,这是元素,还可以应用到XML或者类似于XML的文档上,比如SVG。

  • :disabled – 匹配已禁用的元素,包括input、select以及button元素。

  • :enabled – 匹配已启用的元素,即那些能够被激活或者接受焦点的元素。

  • :checked – 匹配已经针对选定的复选框、单选按钮或选择框选项。

  • :invalid – 根据输入类型中的定义,匹配有非法输入值的元素。

  • :valid – 匹配有合法值的元素。

  • :required – 匹配设置了required属性的元素。

  • :optional – 匹配没有设置required属性的元素。
    #伪元素选择器
    伪元素类似于伪类,但是它不匹配特定状态的元素,而是匹配在文档中没有直接对应HTML元素的特定部分。
    伪元素选择器可能只匹配元素的一部分,甚至向HTML标记中未定义的地方插入内容。

  • ::before – 创建一个伪元素,使其成为匹配元素的第一个子元素。该元素默认是行内元素,可用于插入文字、图片或其他形状。必须指定content属性才能让元素出现,例如:.menu::before。

  • ::after – 创建一个伪元素,使其成为匹配元素的最后一个子元素。该元素默认是行内元素,可用于插入文字、图片或其他形状。必须指定content属性才能让元素出现,例如:.menu::after。

属性选择器

属性选择器用于根据HTML属性匹配元素。其优先级与一个类选择器(0,1,0)相等。

  • [attr] – 匹配的元素拥有指定属性attr,无论属性值是什么,例如:input[disabled]​。
  • [attr=“value”] – 匹配的元素拥有指定属性attr,且属性值等于指定的字符串值,例如:input[type=“radio”]​。
  • [attr^=“value”] – “开头”属性选择器。
  • [attr$=“value”] – “结尾”属性选择器。
  • [attr*=“value”] – “包含”属性选择器。
  • [attr~=“value”] – “空格分隔的列表”属性选择器。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如若转载,请注明出处:http://www.pswp.cn/web/98028.shtml
繁体地址,请注明出处:http://hk.pswp.cn/web/98028.shtml
英文地址,请注明出处:http://en.pswp.cn/web/98028.shtml

如若内容造成侵权/违法违规/事实不符,请联系英文站点网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

自动驾驶中的传感器技术46——Radar(7)

卫星雷达(又称为分布式雷达)主要讲当前雷达的雷达信号处理计算以及雷达目标相关的一些感知算法都迁移到中央域控进行,雷达端基本只负责数据采集,这样做的影响如下: 雷达端成本与功耗降低; 雷达端采样得到的…

【论文阅读】Diff-Privacy: Diffusion-based Face Privacy Protection

基于扩散模型的人脸隐私保护方法——DiffPrivacy,解决了两类人脸隐私任务:匿名化(anonymization)和视觉身份信息隐藏(visual identity information hiding)。1. 研究背景随着人工智能和大数据技术的普及&am…

React 原理篇 - 深入理解虚拟 DOM

一、什么是虚拟 DOM? 在前端开发中,“虚拟 DOM” 是一个高频出现的术语,尤其在 React 生态中被广泛讨论。但很多开发者对它的理解往往停留在 “JS 对象” 这个表层认知上。 实际上,虚拟 DOM 是一种编程概念—— 在这个概念里&…

对汇编的初理解

此处是一个简单的函数,里面将调用了一个函数add()函数这里是函数的原型这里是调用lcd函数产生的汇编语言,翻译过来就是r11,r0cnt(r4cnt,前文有提及),然后调用add函数,此处BL是指会回到指令的下一…

《Python 自动化实战:从零构建一个文件同步工具》

《Python 自动化实战:从零构建一个文件同步工具》 一、开篇引入:为什么我们需要文件同步? 你是否有过这样的困扰: 公司电脑和家里电脑上都有工作项目,每次更新都要手动复制? U 盘频繁传输文件,不仅麻烦还容易出错? 项目文件夹动辄几 G,每次同步都耗时长、效率低? 在…

工业相机与镜头的靶面尺寸详解:选型避坑指南

在机器视觉系统中,相机与镜头的靶面尺寸匹配是一个非常关键却又经常被忽略的细节。选错了,不但影响图像质量,还可能导致画面“黑角”、视野不符、镜头浪费等问题。 今天我们就用通俗易懂的方式,聊一聊相机与镜头靶面尺寸的那些事儿…

使用 Go 和 go-commons 实现内存指标采集并对接 Prometheus

文章目录一、准备工作二、编写内存采集代码三、运行 Exporter四、接入 Prometheus五、可扩展思路总结在运维和监控领域,资源指标采集 是必不可少的一环。CPU、内存、磁盘、网络这些系统资源,需要实时采集并上报到监控系统中。 本文以 内存指标采集 为例&…

webrtc弱网-IntervalBudget类源码分析与算法原理

一、核心功能 IntervalBudget 类用于基于时间窗口的带宽预算管理。它根据设定的目标比特率(kbps)和一个固定时间窗口(500ms),计算在该时间窗口内可用的字节数(即“预算”),并支持预…

深度学习基本模块:RNN 循环神经网络

循环神经网络(RNN)是一种专门用于处理序列数据的神经网络架构。与处理空间数据的卷积神经网络(Conv2D)不同,RNN通过引入循环连接使网络具有"记忆"能力,能够利用之前的信息来影响当前的输出&#…

React18学习笔记(二) React的状态管理工具--Redux,案例--移动端外卖平台

文章目录一.Redux的基础用法1.示例:普通网页中的Redux计步器2.Redux管理数据的流程3.配套工具和环境准备3.1.配套工具3.2.环境准备4.示例:React项目中的Redux计步器思路步骤step1:创建子模块step2:导入子模块step3:注入store实例step4:React组件内使用store中的数据step5:在组件…

34.Socket编程(UDP)(上)

点分十进制字符串IP 转 32位网络序列IP 分析:1)IP转成4字节 2)4字节转成网络序列 思路: "192.168.1.1" 进行字符串划分,以 "." 为分割符,分割出"192",&qu…

Redis的持久化工具包—RDB AOF

文章目录 前言 一、RDB 持久化(快照持久化) 1. 定义 2. RDB 触发机制 (1)手动触发 (2)自动触发 3. RDB 持久化流程 4. RDB 核心配置 5. RDB 优缺点 二、AOF 持久化(日志持久化) 1. 定…

【Web安全】XXL-JOB框架SRC高频漏洞分析总结

文章目录前言一、核心漏洞分类与技术细节二、漏洞关联利用与攻击路径三、版本演进与修复策略四、安全运维建议五、典型漏洞复现环境搭建六、总结前言 XXL-JOB是国内主流的开源分布式任务调度框架,由徐雪里开发维护,以轻量易用、高可用、适配分布式场景等…

Capacitor 打包后接口访问不到的排查经历

我最近在用 Quasar Capacitor 6 做一个 Android App,前端用的是 Vue3 Quasar,打包交给 Capacitor 去跑在手机的 WebView 里,后端是 FastAPI 提供接口。开发模式下一切顺利,浏览器里访问接口没有任何问题,我甚至觉得打…

【正点原子】Linux应用编程入门~概念及环境介绍

应用编程概念 应用编程(也可称为系统编程)与驱动编程、裸机编程有何不同?系统调用;何为库函数;应用程序的 main()函数;应用程序开发环境的介绍;系统调用 定义系统调用(system call&a…

一、HTML 完全指南:从零开始构建网页

文章目录前言一、 HTML 结构认识 HTML 标签HTML 文件基本结构标签层次结构快速生成代码框架二、 HTML 常见标签详解2.1 注释标签2.2 标题标签 (h1 - h6)2.3 段落标签 (p)2.4 换行标签 (br)2.5 格式化标签2.6 图片标签 (img)2.7 超链接标签 (a)2.8 表格标签基本使用合并单元格2.…

基于POI-TL实现动态Word模板的数据填充:【散点图】特殊处理方案

基于POI-TL实现动态Word模板的数据填充:散点图特殊处理方案 在使用POI-TL进行Word模板动态数据填充时,图表生成是一个常见需求。最近在项目中使用POI-TL处理散点图时遇到了一个特殊问题,经过研究后找到了解决方案,特此记录分享。 问题背景 POI-TL作为一款优秀的Java Wor…

使用node-Express框架写一个学校宿舍管理系统练习项目-前后端分离

今天继续分享一个新的练习项目,是使用node做为后端语言,来写的一个前后端分离项目:学校宿舍管理系统。我们如果想掌握一门编程语言,就是需要大量的练习。所以当我们学习到了一些知识,自己想一下 可以拿学到的知识&…

Kafka 运维实战基本操作含命令与最佳实践

1. 基础概览与工具入口 Kafka 发行包的所有 CLI 工具均在 bin/ 目录下。任何工具不带参数运行都会显示所有可用选项。本文命令默认:--bootstrap-server localhost:9092;生产请替换为你的控制面或内网 VIP。 2. 主题管理(创建 / 修改 / 删除 /…

贪心算法应用:航班起降问题详解

Java中的贪心算法应用:航班起降问题详解 贪心算法是一种在每一步选择中都采取当前状态下最优的选择,从而希望导致全局最优解的算法策略。在航班起降问题中,贪心算法可以有效地解决机场跑道调度问题,即如何安排航班的起降顺序以最大…