CSS- 1.1 css选择器

本系列可作为前端学习系列的笔记,代码的运行环境是在HBuilder中,小编会将代码复制下来,大家复制下来就可以练习了,方便大家学习。

HTML系列文章 已经收录在前端专栏,有需要的宝宝们可以点击前端专栏查看!


 系列文章目录

CSS- 1.1 css选择器

CSS- 2.1 实战之图文混排、表格、表单

CSS- 3.1 盒子模型-块级元素、行内元素、行内块级元素和display属性 


目录

 系列文章目录

前言

一、CSS选择器

1. 元素选择器

2. 类选择器

3. ID选择器

4. 属性选择器

5. 后代选择器

6. 子选择器

7. 相邻兄弟选择器

8. 通用兄弟选择器

9. 伪类选择器

10. 伪元素选择器

二、代码实例

1、代码实战及运行

(1)CSS基本选择器

 ①代码

 ②代码运行

(2)CSS复合选择器 

①代码

②代码运行

(3)超链接-伪类选择器 

①代码

②代码运行 

总结


前言

小编作为新晋码农一枚,会定期整理一些写的比较好的代码,作为自己的学习笔记,会试着做一下批注和补充,如转载或者参考他人文献会标明出处,非商用,如有侵权会删改!欢迎大家斧正和讨论!

一、CSS选择器

CSS(层叠样式表)选择器用于选择HTML元素并应用样式。它们是CSS中用于定位元素的基本工具。下面是一些CSS选择器及其用法:

1. 元素选择器

元素选择器用于选择指定类型的HTML元素。

p {color: blue;
}

上面的代码将选择所有的<p>元素,并将其文本颜色设置为蓝色。

2. 类选择器

类选择器用于选择具有特定类属性的元素。类名前面有一个点(.)。

.my-class {font-size: 16px;
}

上面的代码将选择所有具有class="my-class"的元素,并将其字体大小设置为16像素。

3. ID选择器

ID选择器用于选择具有特定ID属性的元素。ID前面有一个井号(#)。

#my-id {background-color: yellow;
}


上面的代码将选择具有id="my-id"的元素,并将其背景颜色设置为黄色。

4. 属性选择器

属性选择器用于选择具有特定属性的元素。

[type="text"] {border: 1px solid black;
}

上面的代码将选择所有type="text"的元素,并为其添加黑色边框。

5. 后代选择器

后代选择器用于选择某个元素内的所有特定后代元素。

div p {margin: 10px;
}

上面的代码将选择所有在<div>元素内的<p>元素,并为其添加10像素的外边距。

6. 子选择器

子选择器用于选择某个元素的直接子元素。

ul > li {list-style-type: none;
}

上面的代码将选择所有作为<ul>直接子元素的<li>元素,并移除其列表标记。

7. 相邻兄弟选择器

(小编认为这里的内容有点点晦涩,附了例子解释)

相邻兄弟选择器用于选择紧接在另一个元素后的元素,且二者有相同的父元素。

h1 + p {font-weight: bold;
}

上面的代码将选择所有紧接在<h1>元素后的<p>元素,并将其字体加粗。

更具体解释一下:假设一个情景,有很多<p>元素,但是只有紧跟在<h1>元素后的<p>元素才需要加粗,这时 的<h1>元素相当于一个定位符号,确定了需要加粗字号的<p>元素的位置

小编这里举个例子:

     	<!-- p{段落$}*4 按tab --><!-- 1.所有段落字体为30px --><!-- 2.段落二加粗变蓝 --><!-- 3.段落3下划线 --><p>段落一</p><p class="bule">段落二</p><h1>定位</h1><p id="id1">段落三</p><p >段落四</p>

 这里的<h1>元素紧邻着的<p>元素,内容是段落三,先看没有添加让<h1>元素后的<p>元素字体加粗的样式时,运行内容为:

当添加让<h1>元素后的<p>元素字体加粗的样式后:可以明显看到段落三字体被加粗了。

h1 + p {font-weight: bold;}

注意:此时的段落四并没有被加粗,这里需要区别于通用兄弟选择器,看一下下面的例子就能明白。

8. 通用兄弟选择器

通用兄弟选择器用于选择在某个元素之后的所有兄弟元素。

h2 ~ p {color: green;
}

上面的代码将选择所有在<h2>元素之后的所有<p>元素,并将其文本颜色设置为绿色。

还是上面的例子,这里的样式使用通用兄弟选择器,没有添加通用兄弟选择器时的代码运行如下:

<!-- p{段落$}*4 按tab --><!-- 1.所有段落字体为30px --><!-- 2.段落二加粗变蓝 --><!-- 3.段落3下划线 --><p>段落一</p><p class="bule">段落二</p><h1>定位</h1><p id="id1">段落三</p><p >段落四</p>

 

添加了通用兄弟选择器后的样式如下:段落三和段落四的字体都被加粗

h1 ~ p {font-weight: bold;}

9. 伪类选择器

伪类选择器用于选择元素的特定状态。

a:hover {color: red;
}

上面的代码将选择鼠标悬停在<a>元素上时的状态,并将其文本颜色设置为红色

这里举例,修改为:鼠标悬停在<a>元素上时,将文本颜色设置为红色

p:hover {color: red;}

可以看到,当鼠标悬停在段落一时,段落一字体变红。

10. 伪元素选择器

伪元素选择器用于选择元素的特定部分。

p::first-line {font-weight: bold;
}

上面的代码将选择<p>元素的第一行文本,并将其字体加粗。

这些基本选择器可以组合使用,以实现更复杂的选择和样式应用。通过灵活运用这些选择器,可以创建出丰富且响应迅速的网页设计。

二、代码实例

这里举例使用的代码如下,大家可以根据给出的基本选择器的举例代码,进行运行调试:

1、代码实战及运行

(1)CSS基本选择器

     ①代码
<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>css基本选择器</title><style type="text/css">/*标签选择器*/p{font-size:30px ;}/*类选择器*/.bule{font-weight: 700;color: blue;}/*id选择器 #id名*/#id1{text-decoration: underline;}img{position: absolute;left: 45%;top: 300px;width: 100px;}/* h1 ~ p {font-weight: bold;}p:hover {color: red;} */</style></head><body><!-- p{段落$}*4 按tab --><!-- 1.所有段落字体为30px --><!-- 2.段落二及段落四加粗变蓝 --><!-- 3.段落3下划线 --><p>段落一</p><p class="bule">段落二</p><h1>定位</h1><p id="id1">段落三</p><p class="bule">段落四</p><a href="../个人主题网站/index.html"><h3 align="center">返回首页</h3></a></body>
</html>
   ②代码运行

 

(2)CSS复合选择器 

   ①代码
<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>css复合选择器</title><style type="text/css">/* 交集选择器 标签选择器类选择器 中间没有空格 */p.p1{color: pink;}/* 并集 基本选择器 中间用逗号链接* */p,.p2,div,span{font-size: 30px;}/* 后代选择器 祖辈在前 后辈在后 中间空格连接 */div span{text-decoration: underline;}div ul li span{color: red;}/* 子选择器 父大于子 */div>span{color: green;}img{position: absolute;left:45%;top: 300px;width:100px;}</style></head><body><p class="p1">段落一</p><p class="p2">段落二</p><h2 class="p1">标题一</h2><div id=""><span id="">希望世界和平</span><ul><li><span>希望世界和平222</span></li></ul></div><a href="../个人主题网站/index.html"><h3 align="center">返回首页</h3></a></body>
</html>
②代码运行

 

(3)超链接-伪类选择器 

   ①代码
<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>超链接-伪类选择器</title><style type="text/css">/* 未被访问 悬停 点击 访问过以后 *//* a:link 等同于a *//* 可以没有hover active 但是必须有Link和visited */a:link{color: red;      /* 将未被访问的链接文本颜色设置为红色。 */font-size: 60px;}a:hover{color: pink;    /* 当鼠标悬停在链接上时,将链接文本颜色更改为粉色 */}a:active{color: green;   /* 当链接被点击时,将链接文本颜色更改为绿色 */}a:visited{color: skyblue;    /* 将已被访问的链接文本颜色设置为天蓝色 */}</style></head><body><a href="cs2-1.html">新闻</a><a ><h3 align="center">返回首页</h3></a><a href="https://www.baidu.com/">百度</a><!-- <a href="../个人主题网站/index.html"><h3 align="center">返回首页</h3></a> --></body>
</html>
②代码运行 


总结

以上就是今天要讲的内容,本文简单记录了css选择器,仅作为一份简单的笔记使用,大家根据注释理解,您的点赞关注收藏就是对小编最大的鼓励!

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

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

相关文章

MongoClient和AsyncIOMotorClient的区别和用法

示例代码&#xff1a; from motor.motor_asyncio import AsyncIOMotorClient from pymongo import MongoClient&#x1f50d; 这两个库分别是&#xff1a; 名字说明举个例子pymongo.MongoClient同步版 的 MongoDB 客户端&#xff08;常规阻塞式操作&#xff09;你在主线程里一…

5.15打卡

浙大疏锦行 DAY 26 函数专题1 知识点回顾&#xff1a; 1. 函数的定义 2. 变量作用域&#xff1a;局部变量和全局变量 3. 函数的参数类型&#xff1a;位置参数、默认参数、不定参数 4. 传递参数的手段&#xff1a;关键词参数 5. 传递参数的顺序&#xff1a;同时出现三种参数…

针对面试-mysql篇

1.如何定位慢查询? 1.1.介绍一下当时产生问题的场景(我们当时的接口测试的时候非常的慢&#xff0c;压测的结果大概5秒钟))&#xff0c;可以监测出哪个接口&#xff0c;最终因为是sql的问题 1.2.我们系统中当时采用了运维工具(Skywalking就是2秒&#xff0c;一旦sql执行超过2秒…

window 显示驱动开发-报告图形内存(三)

图形内存报告示例 示例 1&#xff1a;笔记本电脑上的 128 MB 专用板载图形内存 以下屏幕截图显示了使用 Intel Iris 离散图形适配器运行 Windows 11 的 Surface 笔记本电脑的计算图形内存数。 适配器的可用内存总数为 16424 MB&#xff0c;用于图形用途&#xff0c;细分如下&…

极简主义现代商务风格PPT模版6套一组分享下载

现代商务风格PPT模版下载https://pan.quark.cn/s/12fbc52124d9 第一张PPT模版&#xff0c;简约风&#xff0c;橄榄绿背景&#xff0c;黑色竖条装饰&#xff0c;文字有中英文标题和占位符。需要提取关键元素&#xff1a;简约、橄榄绿、对称布局、占位文本的位置。 风格​&#…

SpringBoot中10种动态修改配置的方法

在SpringBoot应用中&#xff0c;配置信息通常通过application.properties或application.yml文件静态定义&#xff0c;应用启动后这些配置就固定下来了。 但我们常常需要在不重启应用的情况下动态修改配置&#xff0c;以实现灰度发布、A/B测试、动态调整线程池参数、切换功能开…

嵌入式自学第二十二天(5.15)

顺序表和链表 优缺点 存储方式&#xff1a; 顺序表是一段连续的存储单元 链表是逻辑结构连续物理结构&#xff08;在内存中的表现形式&#xff09;不连续 时间性能&#xff0c; 查找顺序表O(1)&#xff1a;下标直接查找 链表 O(n)&#xff1a;从头指针往后遍历才能找到 插入和…

高并发内存池(三):TLS无锁访问以及Central Cache结构设计

目录 前言&#xff1a; 一&#xff0c;thread cache线程局部存储的实现 问题引入 概念说明 基本使用 thread cache TLS的实现 二&#xff0c;Central Cache整体的结构框架 大致结构 span结构 span结构的实现 三&#xff0c;Central Cache大致结构的实现 单例模式 thr…

Ubuntu 安装 Docker(镜像加速)完整教程

Docker 是一款开源的应用容器引擎&#xff0c;允许开发者打包应用及其依赖包到一个轻量级、可移植的容器中。本文将介绍在 Ubuntu 系统上安装 Docker 的步骤。 1. 更新软件源 首先&#xff0c;更新 Ubuntu 系统的软件源&#xff1a; sudo apt update2. 安装基本软件 接下来…

【深度学习】数据集的划分比例到底是选择811还是712?

1 引入 在机器学习中&#xff0c;将数据集划分为训练集&#xff08;Training Set&#xff09;、验证集&#xff08;Validation Set&#xff09;和测试集&#xff08;Test Set&#xff09;是非常标准的步骤。这三个集合各有其用途&#xff1a; 训练集 (Training Set)&#xff…

Mysql刷题 day01

LC 197 上升的温度 需求&#xff1a;编写解决方案&#xff0c;找出与之前&#xff08;昨天的&#xff09;日期相比温度更高的所有日期的 id 。 代码&#xff1a; select w2.id from Weather as w1 join Weather as w2 on DateDiff(w2.recordDate , w1.recordDate) 1 where…

鸿蒙OSUniApp 制作个人信息编辑界面与头像上传功能#三方框架 #Uniapp

UniApp 制作个人信息编辑界面与头像上传功能 前言 最近在做一个社交类小程序时&#xff0c;遇到了需要实现用户资料编辑和头像上传的需求。这个功能看似简单&#xff0c;但要做好用户体验和兼容多端&#xff0c;还是有不少细节需要处理。经过一番摸索&#xff0c;总结出了一套…

科技的成就(六十八)

623、杰文斯悖论 杰文斯悖论是1865年经济学家威廉斯坦利杰文斯提出的一悖论&#xff1a;当技术进步提高了效率&#xff0c;资源消耗不仅没有减少&#xff0c;反而激增。例如&#xff0c;瓦特改良的蒸汽机让煤炭燃烧更加高效&#xff0c;但结果却是煤炭需求飙升。 624、代码混…

荣耀手机,系统MagicOS 9.0 USB配置没有音频来源后无法被adb检测到,无法真机调试的解决办法

荣耀手机&#xff0c;系统MagicOS 9.0 USB配置没有音频来源后无法被adb检测到&#xff0c;无法真机调试的解决办法 前言环境说明操作方法 前言 一直在使用的uni-app真机运行荣耀手机方法&#xff0c;都是通过设置USB配置的音频来源才能成功。突然&#xff0c;因为我的手机的系…

D-Pointer(Pimpl)设计模式(指向实现的指针)

Qt 的 D-Pointer&#xff08;Pimpl&#xff09;设计模式 1. Pimpl 模式简介 Pimpl&#xff08;Pointer to Implementation&#xff09;是一种设计模式&#xff0c;用于将类的接口与实现分离&#xff0c;从而隐藏实现细节&#xff0c;降低编译依赖&#xff0c;提高代码的可维护…

MySQL 8.0 OCP 1Z0-908 101-110题

Q101.which two queries are examples of successful SQL injection attacks? A.SELECT id, name FROM backup_before WHERE name‘; DROP TABLE injection; --’; B. SELECT id, name FROM user WHERE id23 oR id32 OR 11; C. SELECT id, name FROM user WHERE user.id (SEL…

Vue ElementUI原生upload修改字体大小和区域宽度

Vue ElementUI原生upload修改字体大小和区域宽度 修改后 代码 新增的修改样式代码 .upload-demo /deep/ .el-upload-dragger{width: 700px;height: 300px; }原有拖拽组件代码 <!-- 拖拽上传组件 --><el-uploadclass"upload-demo"dragaction"":m…

React和Vue在前端开发中, 通常选择哪一个

React和Vue的选择需结合具体需求&#xff1a; 选React的场景 大型企业级应用&#xff0c;需处理复杂状态&#xff08;如电商、社交平台&#xff09;团队熟悉JavaScript&#xff0c;已有React技术栈积累需要高度灵活的架构&#xff08;React仅专注视图层&#xff0c;可自由搭配…

Python爬虫实战:研究源码还原技术,实现逆向解密

1. 引言 在网络爬虫技术实际应用中,目标网站常采用各种加密手段保护数据传输和业务逻辑。传统逆向解密方法依赖人工分析和调试,效率低下且易出错。随着 Web 应用复杂度提升,特别是 JavaScript 混淆技术广泛应用,传统方法面临更大挑战。 本文提出基于源码还原的逆向解密方法…

什么是alpaca 或 sharegpt 格式的数据集?

环境&#xff1a; LLaMA-Factory 问题描述&#xff1a; alpaca 或 sharegpt 格式的数据集&#xff1f; 解决方案&#xff1a; “Alpaca”和“ShareGPT”格式的数据集&#xff0c;是近年来在开源大语言模型微调和对话数据构建领域比较流行的两种格式。它们主要用于训练和微调…