CSS基础笔记-03选择器

news2024/10/2 22:28:27

CSS基础笔记系列

  • 《CSS基础笔记-01CSS概述》
  • 《CSS基础笔记-02动画》

前言

在前面两篇博客中,我实际上已经使用过了选择器。但到底什么是选择器、有什么作用,我反而不能表达出来。因此,决定记录了我的学习和思考。

什么是选择器

selector是css rule的第一个部分,用于匹配HTML元素,并使用规则中的属性样式化对应元素。

/* CSS syntax */
selector{
	property: value;
}

本文将结合具体的示例来展示:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="utf-8" />
    <title>Tao Te Ching</title>
    <link rel="stylesheet" href="./style.css" />
</head>

<body>
    <h1>第二章(治国)</h1>
    <p class="special"><em>天下皆知美之为美,斯恶已</em>;皆知善之为善,斯不善已。</p>
    <p>有无相生,难易相成,长短相形,高下相倾,音声相和,前后相随,恒也。</p>
    <p>是以圣人处无为之事,行不言之教;万物作而弗始,生而弗有,为而弗恃,<strong>功成而弗居</strong>。夫唯弗居,是以不去。</p>

</body>

</html>

元素选择器

以HTML元素为作为selector。 也叫 标签选择器类型选择器

例如,以

作为选择器,那么所有的p标签都会应用这个样式。

h1 {
    color: blue;
}

p {
    color: blueviolet;
}

strong {
    color: red;
}

em {
    color: gray;
}

在这里插入图片描述

类选择器

类选择器以一个句点(.)开头,会选择文档中应用了这个类的所有标签。例如,使用.highlight将指定的p标签高亮。
在这里插入图片描述

类选择器的组合使用:
在这里插入图片描述

ID选择器

ID选择器以一个句点(#)开头。在html中对指定的元素添加id属性,然后在css中添加对应id的样式。

在这里插入图片描述

属性选择器

用属性选择器来选中带有特定属性的元素。属性名放在[]中。

接下来通过一个无需列表来演示,属性选择器的使用:

<ul>
        <li>第三章</li>
        <li class="chapter4">第四章</li>
        <li class="chapter4 chapter5">第五章</li>
        <li class="chapter4chapter5">第六章</li>
    </ul>
/* 将所有使用了class属性的元素的字体大小设置为20% */
[class]{
    font-size: 20%;
}

/* 将所有含有class属性的li标签的字体大小设置为200% */
li[class]{
    font-size: 200%;
}

/* 匹配仅有chapter4属性值的li标签*/
li[class="chapter4"]{
    background-color: red;
}

/* 匹配只要有chapter4属性值的li标签*/
/* 当class属性有多个值时,每个值用空格分开 */
/* 说明:这个样式会覆盖上面的,因为本样式的权重值更大 */
li[class~="chapter4"]{
    background-color: yellow;
}

伪类选择器(pseudo-class)

用于选择处于特定状态的元素。

伪类就是开头为冒号的关键字:

selector:pseudo-class {
  property: value;
}

例如,我只想让article的第一个段落的文字字体加粗加大,无论任何时候都可以在article的最开始动态插入p标签且保持设置的特定样式始终有效,而不用再修改代码。

article p:first-child{
    font-size: 120%;
    font-weight: bold;
}

像常规的类一样,可以在选择器中将任意数量的伪类链在一起。

伪元素选择器(pseudo-elements)

伪元素是一个附加至选择器末的关键词,允许你对被选择元素的特定部分修改样式

selector::pseudo-element {
  property: value;
}

一个选择器中只能使用一个伪元素。伪元素必须紧跟在语句中的简单选择器/基础选择器之后。

/* 使用伪元素选择器,使段落的第一行文字总是被应用样式 */
/* 而不管屏幕的大小如何变化 */
article p::first-line{
    font-size: 120%;
    font-weight: bold;
}
/* 选择一个<article>元素里面的第一个<p>元素的第一行。 */
article p:first-child::first-line{
    font-size: 120%;
    font-weight: bold;
}
/* 在box类 前插入一个伪元素 */
.box::before {
    content: "hello";
    color: aqua;
    display: block;
    width: 100px;
    height: 100px;
    background-color: brown;
    border: 1px solid black;
}
/* 在box类 后插入一个伪元素 */
.box::after{
    content: "after usage";
    color: blue;
}

关系选择器(combinator)

后代选择器(descendant combinator)

用单个空格来组合两个或多个元素的选择器。

/* 匹配body中的article中的p标签 */
body article p

子代选择器(child combinator)

子代选择器是个大于号(>),只会在选择器选中直接子元素的时候匹配。继承关系上更远的后代则不会匹配。

<ul>
        <li>Unordered item</li>
        <li>Unordered item
            <ol>
                <li>Item 1</li>
                <li>Item 2</li>
            </ol>
        </li>
    </ul>

ul>li {
    /* 非继承属性 */
    border: thick double #32a1ce;
    /* 继承属性 */
    color: red;
}

紧邻兄弟选择器(next-sibling combinator)

紧邻兄弟选择器(+)用来选中恰好处于另一个在继承关系上同级的元素旁边的元素。

<article>
    <h1>一级标题</h1>
      <p>第一段的内容</p>
      <p>第二段的内容</p>
  </article>
h1 + p {
    font-weight: bold;
    background-color: #333;
    color: #fff;
    padding: 2px;
  }

兄弟选择器(subsequent-sibling combinator)

使用(~)来选择任意兄弟元素。

<article>
    <h1>一级标题</h1>
      <p>第一段的内容</p>
      <div>无效内容</div>
      <p>第二段的内容</p>
  </article>
h1 ~ p {
  font-weight: bold;
  background-color: #b03636;
  color: #fff;
  padding: 2px;
}

总结

本文学习了10种选择器,掌握它们的关键:一是先理解,二是多练;多使用才会积累更多的经验,多尝试不同的组合。单纯的去记,我是记不住的!!!另外,关于这篇文章的内容,等有空时录个视频,看起来就会更直观啦!关于cascading、specificity、 inheritanc还有点儿迷,明天再学习下。

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Joplin配合teracloud进行多版本客户端分别笔记同步

最近瞎搜索joplin&#xff0c;意外在github上搜到plugins&#xff0c;插件仓库&#xff0c;里面有一个思维导图的插件我还是蛮喜欢的&#xff0c;结果下载后安装发现&#xff0c;我当前的Jopin的版本如下 &#xff08;Joplin 2.7.15 (prod, win32) 同步版本: 3 配置文件版本: 4…

代码随想录day21 二叉搜索树进阶

530.二叉搜索树的最小绝对差 题目 给你一棵所有节点为非负值的二叉搜索树&#xff0c;请你计算树中任意两节点的差的绝对值的最小值。 示例&#xff1a; 思考 本题有一种笨办法&#xff0c;就是把二叉树的所有结点都存到一个vector里&#xff0c;因为二叉搜索树是左中右排序…

Typora 编辑器 讲解 包括使用方式 快捷键 附带下载地址 (免费破解)

CSDN 成就一亿技术人&#xff01; 今天来讲一下很好用的编辑器 Typora CSDN 成就一亿技术人&#xff01; 什么是Typora&#xff1f; 它是一个 Markdown 编辑器和阅读器&#xff0c;这意味着您可以使用简单的格式代码 &#xff08;Markdown&#xff09;是一种轻量级标记语言&…

MYSQL - SQL优化

插入数据优化 小批量数据 批量插入 最好插入500-1000条比较好 手动提交事务 主键顺序插入 大批量插入数据 主键优化 页分裂 页合并 主键优化设计原则 order by优化 group by优化 limit优化 count优化 count(1)里面不一定必须1&#xff0c;数字都可以 update优化 更新字…

ElasticSearch自定义算分排序(Function Score Query)

使用 function score query&#xff0c;可以修改文档的相关性算分 (query score)&#xff0c;根据新得到的算分排序。 目录 Function Score Query 案例 Function Score Query 几种默认的计算分值的函数&#xff1a; Weight:为每一个文档设置一个简单而不被规范化的权重Fie…

[C]jupyter中使用C

[C]jupyter中使用C 安装使用用处 安装 https://github.com/brendan-rius/jupyter-c-kernel 下拉找到3条命令&#xff0c;装就可以了 mac和linux可用 python3可用&#xff0c; 2不可以 第二条命令可以改为 : python3 install_c_kernel 小总结&#xff1a;如果有问题&#xff0…

[蓝桥 2020]最长递增

最长递增 题目描述 在数列 a1​,a2​,⋯,an​ 中&#xff0c;如果 ai​<ai1​<ai2​<⋯<aj​&#xff0c;则称 ai​ 至 aj​ 为一段递增序列&#xff0c;长度为 j−i1。 定一个数列&#xff0c;请问数列中最长的递增序列有多长。 输入描述 输入的第一行包含一…

使用代理IP保护爬虫访问隐私数据的方法探讨

目录 前言 1. 获取代理IP列表 2. 随机选择代理IP 3. 使用代理IP发送请求 4. 处理代理IP异常 总结 前言 保护爬虫访问隐私数据是一个重要的安全问题。为了保障用户的隐私&#xff0c;很多网站会采取限制措施&#xff0c;如封禁IP或限制访问频率。为了绕过这些限制&#x…

作业三详解

作业3&#xff1a; 在作业1的基础上&#xff0c;整合修改、删除功能&#xff0c;可实现如下功能 1.进入新增页面&#xff0c;页面填入新增数据&#xff0c;提交表单&#xff0c;然后跳转到查询列表页面&#xff0c;列表页面显示所有记录&#xff08;多一条新增的数据&#xff…

大数据平台Bug Bash大扫除最佳实践

一、背景 随着越来越多的"新人"在日常工作以及大促备战中担当大任&#xff0c;我们发现仅了解自身系统业务已不能满足日常系统开发运维需求。为此&#xff0c;大数据平台部门组织了一次Bug Bash活动&#xff0c;既能提升自己对兄弟产品的理解和使用&#xff0c;又能…

SSH 无密登录配置

1)配置 ssh (1)基本语法 ssh 另一台电脑的 IP 地址 (2)ssh 连接时出现 Host key verification failed 的解决方法 [yuxuan@yuxuan102 ~]$ ssh yuxuan103 ➢ 如果出现如下内容 Are you sure you want to continue connecting (yes/no)? ➢ 输入 yes,并回车 (3)退回到 …

C++11 14 17线程

线程类封装 #include<thread> #include<iostream> #include<string>using namespace std::chrono_literals; class MyThread { public:void Main() {std::cout << "MyThread Main" << name << ":" << age;} pr…

RFID传感器|识读器CNS-RFID-01/1S在AGV小车|搬运机器人领域的安装与配置方法

AGV 在运行时候需要根据预设地标点来执行指令&#xff0c;在需要 AGV 在路径线上位置执行某个指令时候&#xff0c;则需要在这个点设置 命令地标点&#xff0c;AGV 通过读取不同地标点编号信息&#xff0c;来执行规定的指令。读取地标点设备为寻址传感器&#xff0c;目前&#…

【demoSURF】室内定位(图像匹配)基础代码实现,包含所有可以出现问题的解法

代码如下 import numpy as np import cv2 from matplotlib import pyplot as plt plt.rcParams[font.sans-serif] [SimHei] # 用来正常显示中文标签 plt.rcParams[axes.unicode_minus] False # 用来正常显示负号img1 cv2.imread("D:/data/North/0007.JPG",0) i…

你是唯一的 uniq

文章目录 你是唯一的 uniq语法默认无参数统计出现频次仅仅显示重复的行仅仅显示不重复的行更多信息 你是唯一的 uniq Linux uniq 命令用于检查及删除文本文件中重复出现的行列&#xff0c;一般与 sort 命令结合使用。 官方定义为&#xff1a; uniq - report or omit repeated…

第15课 利用openCV实现人脸识别

这节课&#xff0c;我们再来看一个简单且实用的例子&#xff1a;人脸识别。这个小例子可以让你进一步领略openCV的强悍。 1.复制demo14并改名为demo15。 2.修改capImg函数&#xff1a; int fmle::capImg() {// 加载人脸检测分类器cv::CascadeClassifier faceCascade;faceCas…

网络知识-以太网技术的发展及网络设备

目 录 一、背景介绍 &#xff08;一&#xff09;网络技术的时代 &#xff08;二&#xff09;以太网技术脱颖而出 二、以太网的工作原理 &#xff08;一&#xff09;、载波侦听多路访问&#xff08;CSMA/CD&#xff09; 1、数据发送流程 2、发送过程解析 3、…

1.4 Unity协程

一、先说接口 接口是不能实例化的&#xff0c;想实例化接口&#xff0c;只能实例化继承了接口的类。 using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.Tasks;namespace InterfaceTest {interface IMyInterfa…

hutool 的 bigExcelWriter.addSelect 失效

原因:可能是下拉列表的数据过多, 解决办法: 添加辅助列 然后只需要往K列加数据就可以了

ssm基于JSP的网络游戏交易系统的设计与实现+jsp论文

摘 要 传统信息的管理大部分依赖于管理人员的手工登记与管理&#xff0c;然而&#xff0c;随着近些年信息技术的迅猛发展&#xff0c;让许多比较老套的信息管理模式进行了更新迭代&#xff0c;商品管理信息因为其管理内容繁杂&#xff0c;管理数量繁多导致手工进行处理不能满足…