当前位置: 首页 > news >正文

CSS中选择器有哪些?(史上最全选择器)

CSS选择器是用来选择和应用样式到HTML元素上的工具。以下是所有主要的CSS选择器的详细分类和描述:

1. 基本选择器

  • 通配符选择器 (*):选择所有元素。例如,* { color: red; } 会将所有元素的文字颜色设置为红色。
  • 元素选择器:选择指定类型的元素。例如,p { margin: 0; } 会将所有<p>元素的外边距设置为0。
  • 类选择器 (.):选择所有具有指定类的元素。例如,.class-name { color: blue; } 会将所有具有class-name类的元素的文字颜色设置为蓝色。
  • ID选择器 (#):选择具有指定ID的单个元素。例如,#element-id { font-size: 16px; } 会将ID为element-id的元素的字体大小设置为16px。
  • 属性选择器 ([attr]):选择具有指定属性的元素。例如,[type="text"] { border: 1px solid black; } 会将所有type属性值为text的元素边框设置为黑色实线。

2. 组合选择器

  • 后代选择器 ( ):选择某元素内的所有指定子元素。例如,div p { color: green; } 会将所有在<div>内部的<p>元素文字颜色设置为绿色。
  • 子选择器 (>):选择某元素的直接子元素。例如,ul > li { list-style-type: none; } 会将所有<ul>的直接子<li>元素的列表样式设置为无。
  • 相邻兄弟选择器 (+):选择某元素后紧跟的相邻兄弟元素。例如,h1 + p { margin-top: 0; } 会将紧跟在<h1>后面的<p>元素的上外边距设置为0。
  • 通用兄弟选择器 (~):选择某元素后面所有的兄弟元素。例如,h1 ~ p { color: purple; } 会将所有<h1>后面的<p>元素的文字颜色设置为紫色。

3. 伪类选择器

  • 结构性伪类

    • :first-child:选择作为其父元素的第一个子元素的元素。例如,p:first-child { font-weight: bold; } 会将父元素的第一个<p>子元素的文字加粗。
    • :last-child:选择作为其父元素的最后一个子元素的元素。
    • :nth-child(n):选择作为其父元素的第n个子元素的元素。例如,li:nth-child(2) { color: red; } 会将第二个<li>元素的文字颜色设置为红色。
    • :nth-of-type(n):选择父元素中第n个指定类型的元素。
    • :not(selector):选择不匹配指定选择器的元素。例如,:not(.special) { color: gray; } 会将所有没有special类的元素文字颜色设置为灰色。
  • 伪元素

    • ::before:在指定元素的内容之前插入内容。例如,p::before { content: "Note: "; color: blue; } 会在每个<p>元素的内容前插入“Note: ”。
    • ::after:在指定元素的内容之后插入内容。例如,p::after { content: "."; } 会在每个<p>元素的内容后插入一个句号。
    • ::first-line:选择元素的第一行文本。
    • ::first-letter:选择元素的第一字母。

4. 属性选择器的变体

  • [attr=value]:选择具有指定属性值的元素。例如,input[type="text"] 选择type属性值为text<input>元素。
  • [attr^="value"]:选择属性值以指定值开头的元素。例如,a[href^="https"] 选择所有href属性以https开头的<a>元素。
  • [attr$="value"]:选择属性值以指定值结尾的元素。例如,img[src$=".jpg"] 选择所有src属性以.jpg结尾的<img>元素。
  • [attr*="value"]:选择属性值包含指定值的元素。例如,a[href*="example"] 选择所有href属性中包含example<a>元素。

5. 组合选择器

  • 相邻兄弟选择器 (+):选择紧接在指定元素之后的元素。例如,h2 + p { margin-top: 0; } 会将紧跟在<h2>后面的<p>元素的上外边距设置为0。
  • 一般兄弟选择器 (~):选择指定元素之后的所有兄弟元素。例如,h2 ~ p { color: gray; } 会将所有在<h2>之后的<p>元素的文字颜色设置为灰色。

相关文章:

CSS中选择器有哪些?(史上最全选择器)

CSS选择器是用来选择和应用样式到HTML元素上的工具。以下是所有主要的CSS选择器的详细分类和描述&#xff1a; 1. 基本选择器 通配符选择器 (*)&#xff1a;选择所有元素。例如&#xff0c;* { color: red; } 会将所有元素的文字颜色设置为红色。元素选择器&#xff1a;选择指…...

本地部署 AI 智能体,Dify 搭建保姆级教程(下):知识库 RAG + API 调用,我捏了一个红楼解读大师

话接上篇&#xff1a; 本地部署 AI 智能体&#xff0c;Dify 搭建保姆级教程&#xff08;上&#xff09;&#xff1a;工作流 Agent&#xff0c;把 AI 接入个人微信 相信大家已经在本地搭建好 Dify 了。 今日分享&#xff0c;继续介绍 Dify 的另外两项重要功能&#xff1a; 知…...

HarmonyOS应用开发者高级认证,Next版本发布后最新题库 - 答案纯享版

这篇文章是高级题库答案纯享版&#xff0c;只有需要选择的选项。如果需要查看所有选项&#xff0c;可以点击下方链接跳转。以考代学&#xff0c;还是推荐点击下方链接&#xff0c;查看完整的题库&#xff0c;边看边学习鸿蒙应用开发。此题库已更新完毕&#xff0c;笔者将不继续…...

基于PHP的文件包含介绍

引言&#xff1a;在实际开发过程中&#xff0c;经常会遇到部分模块功能需要重复使用的情况&#xff0c;比如数据库的增删改查&#xff0c;文件包含通过将需要重复使用的功能模块代码引入其他文件的内容&#xff0c;实现重用代码、分离配置等。然而&#xff0c;如果文件包含操作…...

K7系列FPGA多重启动(Multiboot)

Xilinx 家的 FPGA 支持多重启动功能&#xff08;Multiboot&#xff09;&#xff0c;即可以从多个 bin 文件中进行选择性加载&#xff0c;从而实现对系统的动态更新&#xff0c;或系统功能的动态调整。 这一过程可以通过嵌入在 bit 文件里的 IPROG 命令实现上电后的自动加载。而…...

关于武汉芯景科技有限公司的RS232通信接口芯片XJ3243EEUI开发指南(兼容MAX3243EEUI)

一、芯片引脚介绍 1.芯片引脚 2.引脚描述 二、典型应用电路 三、功能描述 1.Transmitter 通过T1&#xff0c;T2可以将TTL电平转换为RS232电平 2.Receiver 通过R1&#xff0c;R2可以将RS232电平转换为TTL电平 3.工作模式控制 4.INVALID引脚...

TreeSize Free:你的免费磁盘空间管理专家

TreeSize Free是一款专为Windows用户设计的磁盘空间分析工具。它能够帮助用户快速识别并管理那些占用大量空间的文件夹和文件。 功能亮点 快速扫描&#xff1a;TreeSize Free能够迅速扫描整个磁盘卷&#xff0c;展示所有文件夹及其子文件夹的大小&#xff0c;甚至可以细化到单…...

python办公自动化:初识`python-docx`

1.1 什么是python-docx python-docx是一个用于在Python中创建和操作Word文档的库。它提供了一组简洁的API&#xff0c;让开发者可以轻松地生成、修改、和读取Microsoft Word (.docx)文件&#xff0c;而不需要安装Microsoft Office。这使得python-docx成为办公自动化、报告生成…...

LeetCode 算法:划分字母区间 c++

原题链接&#x1f517;&#xff1a;划分字母区间难度&#xff1a;中等⭐️⭐️ 题目 给你一个字符串 s 。我们要把这个字符串划分为尽可能多的片段&#xff0c;同一字母最多出现在一个片段中。 注意&#xff0c;划分结果需要满足&#xff1a;将所有划分结果按顺序连接&#…...

PMP备考指南:策略、时间安排与心得分享

准备和时间安排&#xff0c;我是工作的时间把它顺便考了&#xff0c;大约花了一个月左右时间备考&#xff0c;前面的时间都在筹办婚礼&#xff0c;根本没时间&#xff0c;最后一个月都差点想放弃了&#xff0c;但想想还是冲一把就没有选择延考。 干货见下&#xff1a; ▌&…...

CentOS上通过frp实现HTTPS访问内网

要在CentOS上通过frp实现HTTPS访问内网&#xff0c;你需要按照以下步骤操作&#xff1a; 在外网服务器上安装frps&#xff08;frp服务端&#xff09;。 在外网服务器上配置frps&#xff0c;编辑配置文件frps.ini。 在frps服务器上启动frps服务。 在内网服务器上安装frpc&…...

短视频SDK解决方案,高效集成,助力商业变现

美摄科技&#xff0c;作为业界领先的多媒体技术服务商&#xff0c;其全面升级的短视频SDK解决方案&#xff0c;旨在为开发者与内容创作者提供一站式、高效能的创作工具&#xff0c;让每一个灵感都能瞬间转化为触动人心的视频作品。 【一站式解决方案&#xff0c;重塑短视频创作…...

C++系列-继承方式

继承方式 继承的语法继承方式&#xff1a;继承方式的特点继承方式的举例 继承可以减少重复的代码。继承允许我们依据另一个类来定义一个类&#xff0c;这使得创建和维护一个应用程序变得更容易。基类父类&#xff0c;派生类子类&#xff0c;派生类是在继承了基类的部分成员基础…...

web前端之选项卡的实现、动态添加类名、动态移除类名、动态添加样式、激活、间距、tabBar

MENU 原生(一)原生(二)vue(一) 原生(一) 效果图 html 代码 <div class"card"><div class"tab_bar"><div class"item" onclick"handleTabBar(this)">tabBar1</div><div class"item" onclick&qu…...

sql 优化,提高查询速度

文章目录 一、前言二、建议2.1 使用索引2.2 避免使用select *2.3. 使用表连接代替子查询2.4. 优化WHERE子句&#xff0c;减少返回结果集的大小2.5 用union all代替union2.6 使用合适的聚合策略2.7 避免在WHERE子句中使用函数2.8 使用EXPLAIN分析查询2.9 小表驱动大表2.10 使用窗…...

springboot后端开发-自定义参数校验器

背景 在使用springboot进行后端开发的时候&#xff0c;经常会遇到数据校验的问题&#xff0c; 有时候可能默认的校验器不足以满足自己的需求&#xff0c; 这个时候就需要开发一个自己的校验器 在 Spring Boot 中自定义参数校验器通常涉及以下几个步骤&#xff1a; 1. 定义注解…...

springboot社区帮扶对象管理系统论文源码调试讲解

第2章 开发环境与技术 社区帮扶对象管理系统的编码实现需要搭建一定的环境和使用相应的技术&#xff0c;接下来的内容就是对社区帮扶对象管理系统用到的技术和工具进行介绍。 2.1 MYSQL数据库 本课题所开发的应用程序在数据操作方面是不可预知的&#xff0c;是经常变动的&…...

EmguCV学习笔记 VB.Net 6.2 轮廓处理

版权声明&#xff1a;本文为博主原创文章&#xff0c;转载请在显著位置标明本文出处以及作者网名&#xff0c;未经作者允许不得用于商业目的。 EmguCV是一个基于OpenCV的开源免费的跨平台计算机视觉库,它向C#和VB.NET开发者提供了OpenCV库的大部分功能。 教程VB.net版本请访问…...

【Python的魅力】:利用Pygame实现游戏坦克大战——含完整源码

文章目录 一、游戏运行效果二、代码实现2.1 项目搭建2.2 加载我方坦克2.3 加载敌方坦克2.4 添加爆炸效果2.5 坦克大战之音效处理 三、完整代码 一、游戏运行效果 二、代码实现 坦克大战游戏 2.1 项目搭建 本游戏主要分为两个对象&#xff0c;分别是我方坦克和敌方坦克。用户可…...

【机器学习】经典CNN架构

&#x1f308;个人主页: 鑫宝Code &#x1f525;热门专栏: 闲话杂谈&#xff5c; 炫酷HTML | JavaScript基础 ​&#x1f4ab;个人格言: "如无必要&#xff0c;勿增实体" 文章目录 经典CNN架构1. 引言2. LeNet3. AlexNet4. VGGNet5. GoogLeNet(Inception)6. Res…...

利用最小二乘法找圆心和半径

#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...

Linux相关概念和易错知识点(42)(TCP的连接管理、可靠性、面临复杂网络的处理)

目录 1.TCP的连接管理机制&#xff08;1&#xff09;三次握手①握手过程②对握手过程的理解 &#xff08;2&#xff09;四次挥手&#xff08;3&#xff09;握手和挥手的触发&#xff08;4&#xff09;状态切换①挥手过程中状态的切换②握手过程中状态的切换 2.TCP的可靠性&…...

MMaDA: Multimodal Large Diffusion Language Models

CODE &#xff1a; https://github.com/Gen-Verse/MMaDA Abstract 我们介绍了一种新型的多模态扩散基础模型MMaDA&#xff0c;它被设计用于在文本推理、多模态理解和文本到图像生成等不同领域实现卓越的性能。该方法的特点是三个关键创新:(i) MMaDA采用统一的扩散架构&#xf…...

JVM暂停(Stop-The-World,STW)的原因分类及对应排查方案

JVM暂停(Stop-The-World,STW)的完整原因分类及对应排查方案,结合JVM运行机制和常见故障场景整理而成: 一、GC相关暂停​​ 1. ​​安全点(Safepoint)阻塞​​ ​​现象​​:JVM暂停但无GC日志,日志显示No GCs detected。​​原因​​:JVM等待所有线程进入安全点(如…...

项目部署到Linux上时遇到的错误(Redis,MySQL,无法正确连接,地址占用问题)

Redis无法正确连接 在运行jar包时出现了这样的错误 查询得知问题核心在于Redis连接失败&#xff0c;具体原因是客户端发送了密码认证请求&#xff0c;但Redis服务器未设置密码 1.为Redis设置密码&#xff08;匹配客户端配置&#xff09; 步骤&#xff1a; 1&#xff09;.修…...

Matlab实现任意伪彩色图像可视化显示

Matlab实现任意伪彩色图像可视化显示 1、灰度原始图像2、RGB彩色原始图像 在科研研究中&#xff0c;如何展示好看的实验结果图像非常重要&#xff01;&#xff01;&#xff01; 1、灰度原始图像 灰度图像每个像素点只有一个数值&#xff0c;代表该点的​​亮度&#xff08;或…...

数据库——redis

一、Redis 介绍 1. 概述 Redis&#xff08;Remote Dictionary Server&#xff09;是一个开源的、高性能的内存键值数据库系统&#xff0c;具有以下核心特点&#xff1a; 内存存储架构&#xff1a;数据主要存储在内存中&#xff0c;提供微秒级的读写响应 多数据结构支持&…...

【iOS】 Block再学习

iOS Block再学习 文章目录 iOS Block再学习前言Block的三种类型__ NSGlobalBlock____ NSMallocBlock____ NSStackBlock__小结 Block底层分析Block的结构捕获自由变量捕获全局(静态)变量捕获静态变量__block修饰符forwarding指针 Block的copy时机block作为函数返回值将block赋给…...

Java中HashMap底层原理深度解析:从数据结构到红黑树优化

一、HashMap概述与核心特性 HashMap作为Java集合框架中最常用的数据结构之一&#xff0c;是基于哈希表的Map接口非同步实现。它允许使用null键和null值&#xff08;但只能有一个null键&#xff09;&#xff0c;并且不保证映射顺序的恒久不变。与Hashtable相比&#xff0c;Hash…...

标注工具核心架构分析——主窗口的图像显示

&#x1f3d7;️ 标注工具核心架构分析 &#x1f4cb; 系统概述 主要有两个核心类&#xff0c;采用经典的 Scene-View 架构模式&#xff1a; &#x1f3af; 核心类结构 1. AnnotationScene (QGraphicsScene子类) 主要负责标注场景的管理和交互 &#x1f527; 关键函数&…...