CSS- 1.1 css选择器

news2025/5/17 1:50:53

本系列可作为前端学习系列的笔记,代码的运行环境是在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.coloradmin.cn/o/2377274.html

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

相关文章

ABP-Book Store Application中文讲解 - Part 2: The Book List Page

本章用于介绍如何创建Book List Page。 TBD 1. 汇总 ABP-Book Store Application中文讲解-汇总-CSDN博客 2. 前一章 ABP-Book Store Application中文讲解 - Part 1: Creating the Server Side 项目之间的引用关系。 目录 1. 多语言配置 1.1 zh-Hans.json 1.2 en.jso…

08 web 自动化之 PO 设计模式详解

文章目录 一、什么是 POM二、如何基于 POM 进行自动化框架架构&#xff1f;1、base 层封装2、pageobjects 层封装3、TestCases 层封装 三、元素和方法分离&数据分离1、哪些部分可以进行分离2、示例代码 四、总结 一、什么是 POM POM page object model 页面对象模型 WEB 自…

langchain4j集成QWen、Redis聊天记忆持久化

langchain4j实现聊天记忆默认是基于进程内存的方式&#xff0c;InMemoryChatMemoryStore是具体的实现了&#xff0c;是将聊天记录到一个map中&#xff0c;如果用户大的话&#xff0c;会造成内存溢出以及数据安全问题。位了解决这个问题 langchain4提供了ChatMemoryStore接口&am…

WebGL图形编程实战【7】:变换流水线 × 坐标系与矩阵精讲

变换流水线 #mermaid-svg-Omabd9LSNCdIvWqB {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16px;fill:#333;}#mermaid-svg-Omabd9LSNCdIvWqB .error-icon{fill:#552222;}#mermaid-svg-Omabd9LSNCdIvWqB .error-text{fill:#552222;stroke:#552222;…

DVWA靶场通关笔记-SQL注入(SQL Injection Medium级别)

目录 一、SQL Injection 二、代码审计&#xff08;Medium级别&#xff09; 1、源码分析 &#xff08;1&#xff09;index.php &#xff08;2&#xff09;Medium.php 2、渗透思路 &#xff08;1&#xff09;SQL安全问题分析 &#xff08;2&#xff09;SQL渗透思路 三、…

vue异步导入

vue的异步导入 大家开发vue的时候或多或少路由的异步导入 component: () >import(“/views/A_centerControl/intelligent-control/access-user-group”),当然这是路由页面&#xff0c;那么组件也是可以异步导入的 使用方式 组件的异步导入非常简单&#xff0c;主要是一个…

2025年,如何制作并部署一个完整的个人博客网站

欢迎访问我的个人博客网站&#xff1a;欢迎来到Turnin的个人博客 github开源地址&#xff1a;https://github.com/Re-restart/my_website 前言 2024年年初&#xff0c;从dji实习回来之后&#xff0c;我一直想着拓宽自己的知识边界。在那里我发现虽然大家不用java&#xff0c;…

腾讯云运营开发 golang一面

redis为什么单线程会快 每秒10w吞吐量 io多路复用 一个文件描述符整体拷贝&#xff1b;调用epoll_ctl 单个传递 内核遍历文件描述符判断是否有事件发送&#xff1b;回调函数列表维护 修改有事件发送的socket为可读或可写&#xff0c;返回整个文件描述符&#xff1b;返回链…

一个简单的静态页面

这个页面采用了现代化的 UI 设计&#xff0c;包括卡片式布局、微交互动画、分层设计和响应式结构。页面结构清晰&#xff0c;包含导航栏、英雄区域、功能介绍、产品特性、用户评价和联系表单等完整组件&#xff0c;可作为企业官网或产品介绍页面的基础模板。 登录后复制 <!D…

使用 163 邮箱实现 Spring Boot 邮箱验证码登录

使用 163 邮箱实现 Spring Boot 邮箱验证码登录 本文将详细介绍如何使用网易 163 邮箱作为 SMTP 邮件服务器&#xff0c;实现 Spring Boot 项目中的邮件验证码发送功能&#xff0c;并解决常见配置报错问题。 一、为什么需要邮箱授权码&#xff1f; 出于安全考虑&#xff0c;大…

多模态大语言模型arxiv论文略读(六十八)

Image-of-Thought Prompting for Visual Reasoning Refinement in Multimodal Large Language Models ➡️ 论文标题&#xff1a;Image-of-Thought Prompting for Visual Reasoning Refinement in Multimodal Large Language Models ➡️ 论文作者&#xff1a;Qiji Zhou, Ruoc…

APS「多目标平衡算法」如何破解效率与弹性的永恒博弈

APS&#xff08;高级计划与排程&#xff09;系统作为企业智能制造的核心引擎&#xff0c;通过整合需求预测、产能规划、生产调度、物料管理及数据分析等模块&#xff0c;构建了覆盖产品全生产流程的“感知-决策-执行-优化”闭环体系。 精准需求预测 APS系统通过构建需求特征数…

网张实验操作-防火墙+NAT

实验目的 了解防火墙&#xff08;ENSP中的USG5500&#xff09;域间转发策略配置、NAT&#xff08;与路由器NAT配置命令不同&#xff09;配置。 网络拓扑 两个防火墙连接分别连接一个内网&#xff0c;中间通过路由器连接。配置NAT之后&#xff0c;内网PC可以ping公网&#xf…

05 web 自动化之 selenium 下拉鼠标键盘文件上传

文章目录 一、下拉框操作二、键盘操作三、鼠标操作四、日期控件五、滚动条操作六、文件上传七、定位windows窗口及窗口的元素总结&#xff1a;页面及元素常用操作 一、下拉框操作 from selenium.webdriver.support.select import Select import time from selenium.webdriver.…

Spring Cloud探索之旅:从零搭建微服务雏形 (Eureka, LoadBalancer 与 OpenFeign实战)

引言 大家好&#xff01;近期&#xff0c;我踏上了一段深入学习Spring Cloud构建微服务应用的旅程。我从项目初始化开始&#xff0c;逐步搭建了一个具备服务注册与发现、客户端负载均衡以及声明式服务调用功能的基础微服务系统。本文旨在记录这一阶段的核心学习内容与实践成果…

当 AI 邂逅丝路:揭秘「丝路智旅」,用 RAG 重塑中阿文化旅游体验

目录 系统命名:丝路智旅 (Silk Road Intelligent Travel)系统概述系统架构设计系统功能模块技术选型:为何是它们?系统优势与特点未来展望与扩展总结在数字浪潮席卷全球的今天,古老的丝绸之路正在以一种全新的方式焕发生机。当深厚的文化底蕴遇上尖端的人工智能技术,会碰撞…

18.Excel数据透视表:第1部分创建数据透视表

一 什么是数据透视表 通过万花筒可以用不同的方式査看里面画面图像&#xff0c;在excel中可以将数据透视表看作是对准数据的万花筒&#xff0c;用不同角度去观察数据&#xff0c;也可以旋转数据&#xff0c;对数据进行重新排列&#xff0c;对大量的数据可以快速的汇总和建立交叉…

CSS AI 通义灵码 VSCode插件安装与功能详解

简介 在前端开发领域&#xff0c;页面调试一直是个繁琐的过程&#xff0c;而传统开发中美工与前端的对接也常常出现问题。如今&#xff0c;阿里云技术团队推出的通义灵码智能编码助手&#xff0c;为前端开发者带来了新的解决方案&#xff0c;让开发者可以像指挥者一样&#xf…

【Linux网络】TCP全连接队列

TCP 相关实验 理解 listen 的第二个参数 基于刚才封装的 TcpSocket 实现以下测试代码对于服务器, listen 的第二个参数设置为 1, 并且不调用 accept测试代码链接 test_server.cc #include "tcp_socket.hpp"int main(int argc, char* argv[]) {if (argc ! 3) {pri…

HTML 颜色全解析:从命名规则到 RGBA/HSL 值,附透明度设置与场景应用指南

一、HTML 颜色系统详解 HTML 中的颜色可以通过多种方式定义&#xff0c;包括颜色名称、RGB 值、十六进制值、HSL 值等&#xff0c;同时支持透明度调整。以下是详细分类及应用场景&#xff1a; 1. 颜色名称&#xff08;预定义关键字&#xff09; HTML 预定义了 140 个标准颜色名…