CSS- 4.3 绝对定位(position: absolute)学校官网导航栏实例

news2025/5/19 7:49:09

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

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

点赞关注不迷路!您的点赞、关注和收藏是对小编最大的支持和鼓励!

系列文章目录

CSS- 1.1 css选择器

CSS- 2.1 实战之图文混排、表格、表单、学校官网一级导航栏

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

CSS- 4.1 浮动(Float)

CSS- 4.2 相对定位(position: relative)

CSS- 4.3 绝对定位(position: absolute)&学校官网导航栏实例

CSS- 4.4 固定定位(fixed)& 咖啡售卖官网实例 


目录

系列文章目录

前言

一、CSS 定位之绝对定位(absolute)详解

1、绝对定位(absolute)的基本概念

2、绝对定位的核心特性

1. 脱离文档流

2. 定位基准点

3. 定位属性

3、绝对定位的常见应用场景

1. 创建浮动元素

2. 创建下拉菜单

4. 创建固定宽高比的元素

4、绝对定位的注意事项

1. 父元素需设置定位

2. 层叠上下文

3. 响应式设计中的挑战

5、绝对定位与其他定位方式的比较

6、最佳实践建议

二、代码实例

1.练习代码实例如下:

2.学校导航栏实例如下:

总结


前言

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

一、CSS 定位之绝对定位(absolute)详解

1、绝对定位(absolute)的基本概念

绝对定位(position: absolute)是CSS中一种强大的定位方式,它允许元素脱离正常的文档流,相对于其最近的已定位祖先元素进行定位。如果没有已定位的祖先元素,则相对于初始包含块(通常是视口)定位。

2、绝对定位的核心特性

1. 脱离文档流

  • 绝对定位的元素不再占据原始文档空间,其他元素会忽略它的存在,就好像它从文档中"消失"了一样
  • 示例:

html

<div class="container">
  <div class="normal">普通元素</div>
  <div class="absolute">绝对定位元素</div>
  <div class="normal">另一个普通元素</div>
</div>

css

.container { border: 1px solid #ccc; padding: 20px; }
.normal { background: #eee; margin: 10px 0; padding: 10px; }
.absolute { 
  position: absolute; 
  top: 0; 
  right: 0; 
  background: #f00; 
  color: white; 
  padding: 10px; 
}

效果:绝对定位元素会覆盖在普通元素上,且不占用空间

2. 定位基准点

  • 绝对定位元素会相对于最近的已定位祖先元素定位
  • "已定位"指的是祖先元素的position值为relativeabsolutefixedsticky
  • 如果没有这样的祖先元素,则相对于初始包含块(通常是视口)

3. 定位属性

  • 使用toprightbottomleft属性来精确控制位置
  • 示例:

css

.absolute {
  position: absolute;
  top: 50px;
  left: 100px;
  width: 200px;
  height: 100px;
}

3、绝对定位的常见应用场景

1. 创建浮动元素

css

.float-box {
  position: absolute;
  top: 20px;
  right: 20px;
  width: 300px;
  background: rgba(255,255,255,0.8);
  padding: 15px;
}

2. 创建下拉菜单

html

<div class="dropdown">
  <button>菜单</button>
  <ul class="dropdown-menu">
    <li>选项1</li>
    <li>选项2</li>
    <li>选项3</li>
  </ul>
</div>

css

.dropdown {
  position: relative;
  display: inline-block;
}
.dropdown-menu {
  position: absolute;
  top: 100%;
  left: 0;
  display: none;
  background: white;
  box-shadow: 0 2px 5px rgba(0,0,0,0.2);
}
.dropdown:hover .dropdown-menu {
  display: block;
}

鼠标悬停在菜单按钮式,出现选项


3. 创建工具提示

html

<span class="tooltip" data-tooltip="这是提示文本">悬停查看</span>

<!-- 这里如果弹出的文本看不到,可以添加<br>符号-->

css

.tooltip {
  position: relative;
  cursor: pointer;
}
.tooltip::after {
  content: attr(data-tooltip);
  position: absolute;
  bottom: 100%;
  left: 50%;
  transform: translateX(-50%);
  background: #333;
  color: white;
  padding: 5px 10px;
  border-radius: 4px;
  font-size: 14px;
  white-space: nowrap;
  opacity: 0;
  transition: opacity 0.3s;
}
.tooltip:hover::after {
  opacity: 1;
}

鼠标悬停时,上方弹出提示句: 

4. 创建固定宽高比的元素

css

.aspect-ratio-box {
  position: relative;
  width: 100%;
  padding-top: 56.25%; /* 16:9 宽高比 */
}
.aspect-ratio-content {
  position: absolute;
  top: 0;
  left: 0;
  width: 100%;
  height: 100%;
}

4、绝对定位的注意事项

1. 父元素需设置定位

  • 为了让绝对定位元素相对于特定父元素定位,父元素需要设置position: relative(或其他非static值)
  • 示例:

html

<div class="parent">
  <div class="child">绝对定位子元素</div>
</div>

css

.parent {
  position: relative;
  height: 200px;
  border: 1px solid #ccc;
}
.child {
  position: absolute;
  top: 20px;
  left: 20px;
  background: #f00;
  color: white;
  padding: 10px;
}

2. 层叠上下文

  • 绝对定位元素会创建新的层叠上下文(当设置了z-index值时)
  • 示例:

css

.box1 {
  position: absolute;
  top: 0;
  left: 0;
  z-index: 1;
  background: rgba(255,0,0,0.5);
}
.box2 {
  position: absolute;
  top: 50px;
  left: 50px;
  z-index: 2;
  background: rgba(0,0,255,0.5);
}

3. 响应式设计中的挑战

  • 绝对定位元素可能不适合响应式布局,因为它们不随页面布局变化而自动调整
  • 在响应式设计中,可能需要使用媒体查询调整绝对定位元素的位置

5、绝对定位与其他定位方式的比较

定位方式是否脱离文档流定位基准点适用场景
static (默认)正常文档流默认布局
relative相对于自身原始位置微调元素位置
absolute相对于最近的已定位祖先元素创建浮动元素、工具提示等
fixed相对于视口固定导航栏、返回顶部按钮
sticky否(滚动时是)相对于最近的滚动祖先和视口粘性头部、侧边栏

6、最佳实践建议

  1. 明确基准点:确保绝对定位元素有明确的定位基准点(通常通过父元素设置position: relative

  2. 避免过度使用:绝对定位会破坏文档流,过度使用可能导致布局难以维护

  3. 考虑响应式:在响应式设计中,可能需要为不同屏幕尺寸设置不同的定位值

  4. 结合其他属性:常与z-indextransform等属性配合使用

  5. 性能考虑:绝对定位元素可能影响渲染性能,特别是在大量使用时

绝对定位是CSS布局中非常有用的工具,但需要谨慎使用,特别是在需要响应式设计的项目中。理解其工作原理和与其他定位方式的区别,可以帮助开发者更有效地使用它来实现各种布局效果。

二、代码实例

1.练习代码实例如下:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>定位-绝对定位absolute</title>
		<style type="text/css">
			.div1 {
				width: 100px;
				height: 100px;
				background-color: red;
				
			}

			.div2 {
				width: 100px;
				height: 100px;
				background-color: blue;
				position: absolute;
				left: 100px;
				/* 离本盒子最近的一个已经定位的祖先元素 最近&已经定位&祖先元素 默认为浏览器的左上角 */
			}

			.div3 {
				
				width: 100px;
				height: 100px;
				background-color: green;
				
			}
			.father {
				position: relative;
			}
		</style>
	</head>
	<body>
		<div class="father">
			<div class="div1"></div>
			<div class="div2"></div>
			<div class="div3"></div>
		</div>
			
	</body>
</html>

代码运行:

2.学校导航栏实例如下:

html

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<link rel="stylesheet" type="text/css" href="../css/cs4-6.css" />
	</head>
	<body>
		<div class="nvg">
			<ul>
				<li><a href="#">学院概况</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">党政机构</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">院系设置</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">人才培养</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">师资队伍</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">教学资源</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">科学研究</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				<li><a href="#">招生就业</a>
					<ul>
						<li><a href="#">学院简介</a></li>
						<li><a href="#">历史沿革</a></li>
						<li><a href="#">现任领导</a></li>
						<li><a href="#">学院漫游</a></li>
					</ul>
				</li>
				
			</ul>
		</div>
	</body>
</html>

 CSS

/* 导航栏的父盒子 */
* {
	padding: 0px;
}
.nvg {
	width: 1376px;
	height: 42px;
	/* border: 1px solid black; */
	margin: 10px auto;
}
/* 一级二级导航栏框架 */
.nvg ul {
	list-style-type: none;
}
/* 一级导航栏 */
/* .nvg>ul>li {
	list-style-type: none;
} */
.nvg>ul>li:hover ul{
	display: block;
}
/* 二级导航栏 */
.nvg>ul>li>ul {
	display: none;
	position: absolute;
	top: 42px;
	z-index: 999;
}
/* 每一个li */
.nvg ul li {
	width: 170px;
	height: 40px;
	background-color: #996600;
	border: 1px solid #CCCCCC;
	position: relative;
	float: left;
}
.nvg a:link,a:visited {
	text-decoration: none;
	font: 20px "times new roman";
	color: white;
	display: block;
	width: 170px;
	height: 40px;
	text-align: center;
	line-height: 40px;
}
.nvg a:hover {
	background-color: #492002;
}

代码运行如下:

当鼠标悬停 在学校概况 时(一级导航栏),出现下拉选项:

当鼠标悬停 在 人才培养 时(一级导航栏),出现下拉选项: 


总结

以上就是今天要讲的内容,本文简单记录了CSS- 4.3 绝对定位(position: absolute)以及学校导航栏实例,仅作为一份简单的笔记使用,大家根据注释理解

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

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

相关文章

Seata源码—6.Seata AT模式的数据源代理一

大纲 1.Seata的Resource资源接口源码 2.Seata数据源连接池代理的实现源码 3.Client向Server发起注册RM的源码 4.Client向Server注册RM时的交互源码 5.数据源连接代理与SQL句柄代理的初始化源码 6.Seata基于SQL句柄代理执行SQL的源码 7.执行SQL语句前取消自动提交事务的源…

计算机科技笔记: 容错计算机设计05 n模冗余系统 TMR 三模冗余系统

NMR&#xff08;N-Modular Redundancy&#xff0c;N 模冗余&#xff09;是一种通用的容错设计架构&#xff0c;通过引入 N 个冗余模块&#xff08;N ≥ 3 且为奇数&#xff09;&#xff0c;并采用多数投票机制&#xff0c;来提升系统的容错能力与可靠性。单个模块如果可靠性小于…

Spring Boot 与 RabbitMQ 的深度集成实践(一)

引言 ** 在当今的分布式系统架构中&#xff0c;随着业务复杂度的不断提升以及系统规模的持续扩张&#xff0c;如何实现系统组件之间高效、可靠的通信成为了关键问题。消息队列作为一种重要的中间件技术&#xff0c;应运而生并发挥着举足轻重的作用。 消息队列的核心价值在于其…

黑马程序员2024新版C++笔记 第2章 语句

1.if逻辑判断语句 语法主体&#xff1a; if(要执行的判断&#xff0c;结果是bool型){判断结果是true会执行的代码; } 2.AI大模型辅助编程 在Clion中搜索并安装对应插件&#xff1a; 右上角齿轮点击后找到插件(TRONGYI LINGMA和IFLYCODE)安装后重启ide即可。 重启后会有通义登…

前端动画库 Anime.js 的V4 版本,兼容 Vue、React

前端动画库 Anime.js 更新了 V4 版本&#xff0c;并对其官网进行了全面更新&#xff0c;增加了许多令人惊艳的效果&#xff0c;尤其是时间轴动画效果&#xff0c;让开发者可以更精确地控制动画节奏。 这一版本的发布不仅带来了全新的模块化 API 和显著的性能提升&#xff0c;还…

用 PyTorch 从零实现简易GPT(Transformer 模型)

用 PyTorch 从零实现简易GPT&#xff08;Transformer 模型&#xff09; 本文将结合示例代码&#xff0c;通俗易懂地拆解大模型&#xff08;Transformer&#xff09;从数据预处理到推理预测的核心组件与流程&#xff0c;并通过 Mermaid 流程图直观展示整体架构。文章结构分为四…

【通用大模型】Serper API 详解:搜索引擎数据获取的核心工具

Serper API 详解&#xff1a;搜索引擎数据获取的核心工具 一、Serper API 的定义与核心功能二、技术架构与核心优势2.1 技术实现原理2.2 对比传统方案的突破性优势 三、典型应用场景与代码示例3.1 SEO 监控系统3.2 竞品广告分析 四、使用成本与配额策略五、开发者注意事项六、替…

Spring3+Vue3项目中的知识点——JWT

全称&#xff1a;JOSN Web Token 定义了一种简洁的、自包含的格式&#xff0c;用于通信双方以json数据格式的安全传输信息 组成&#xff1a; 第一部分&#xff1a;Header&#xff08;头&#xff09;&#xff0c;记录令牌类型、签名算法等。 第二部分&#xff1a;Payload&am…

python3GUI--智慧交通分析平台:By:PyQt5+YOLOv8(详细介绍)

文章目录 一&#xff0e;前言二&#xff0e;效果预览1.目标识别与检测2.可视化展示1.车流量统计2. 目标类别占比3. 拥堵情况展示4.目标数量可视化 3.控制台4.核心内容区1.目标检测参数2.帧转QPixmap3.数据管理 5.项目结构 三&#xff0e;总结 平台规定gif最大5M&#xff0c;所以…

Linux任务管理与守护进程

一、任务管理 &#xff08;一&#xff09;进程组、作业、会话概念 &#xff08;1&#xff09;进程组概念&#xff1a;进程组是由一个或多个进程组成的集合&#xff0c;这些进程在某些方面具有关联性。在操作系统中&#xff0c;进程组是用于对进程进行分组管理的一种机制。每个…

C#里与嵌入式系统W5500网络通讯(2)

在嵌入式代码里,需要从嵌入式的MCU访问W5500芯片。 这个是通过SPI通讯来实现的,所以要先连接SPI的硬件通讯线路。 接着下来,就是怎么样访问这个芯片了。 要访问这个芯片,需要通过SPI来发送数据,而发送数据又要有一定的约定格式, 于是芯片厂商就定义下面的通讯格式: …

EMQX开源版安装指南:Linux/Windows全攻略

EMQX开源版安装教程-linux/windows 因最近自己需要使用MQTT&#xff0c;需要搭建一个MQTT服务器&#xff0c;所以想到了很久以前用到的EMQX。但是当时的EMQX使用的是开源版的&#xff0c;在官网可以直接下载。而现在再次打开官网时发现怎么也找不大开源版本了&#xff0c;所以…

【计算机视觉】OpenCV实战项目:GraspPicture 项目深度解析:基于图像分割的抓取点检测系统

GraspPicture 项目深度解析&#xff1a;基于图像分割的抓取点检测系统 一、项目概述项目特点 二、项目运行方式与执行步骤&#xff08;一&#xff09;环境准备&#xff08;二&#xff09;项目结构&#xff08;三&#xff09;执行步骤 三、重要逻辑代码解析&#xff08;一&#…

MySQL 数据库备份与还原

作者&#xff1a;IvanCodes 日期&#xff1a;2025年5月18日 专栏&#xff1a;MySQL教程 思维导图 备份 (Backup) 与 冗余 (Redundancy) 的核心区别: &#x1f3af; 备份是指创建数据的副本并将其存储在不同位置或介质&#xff0c;主要目的是在发生数据丢失、损坏或逻辑错误时进…

Kubernetes控制平面组件:Kubelet详解(四):gRPC 与 CRI gRPC实现

云原生学习路线导航页&#xff08;持续更新中&#xff09; kubernetes学习系列快捷链接 Kubernetes架构原则和对象设计&#xff08;一&#xff09;Kubernetes架构原则和对象设计&#xff08;二&#xff09;Kubernetes架构原则和对象设计&#xff08;三&#xff09;Kubernetes控…

javax.servlet.Filter 介绍-笔记

1.javax.servlet.Filter 简介 javax.servlet.Filter 是 Java Servlet API 中的一个核心接口&#xff0c;用于在请求到达目标资源&#xff08;如 Servlet 或 JSP&#xff09;之前或响应返回给客户端之前执行预处理或后处理操作。它常用于实现与业务逻辑无关的通用功能&#xff…

Win 11开始菜单图标变成白色怎么办?

在使用windows 11的过程中&#xff0c;有时候开始菜单的某些程序图标变成白色的文件形式&#xff0c;但是程序可以正常打开&#xff0c;这个如何解决呢&#xff1f; 这通常是由于快捷方式出了问题&#xff0c;下面跟着操作步骤来解决吧。 1、右键有问题的软件&#xff0c;打开…

入门OpenTelemetry——应用自动埋点

埋点 什么是埋点 埋点&#xff0c;本质就是在你的应用程序里&#xff0c;在重要位置插入采集代码&#xff0c;比如&#xff1a; 收集请求开始和结束的时间收集数据库查询时间收集函数调用链路信息收集异常信息 这些埋点数据&#xff08;Trace、Metrics、Logs&#xff09;被…

C语言链表的操作

初学 初学C语言时&#xff0c;对于链表节点的定义一般是这样的&#xff1a; typedef struct node {int data;struct node *next; } Node; 向链表中添加节点&#xff1a; void addNode(Node **head, int data) {Node *newNode (Node*)malloc(sizeof(Node));newNode->dat…

芯片生态链深度解析(二):基础设备篇——人类精密制造的“巅峰对决”

【开篇&#xff1a;设备——芯片工业的“剑与盾”】 当ASML的EUV光刻机以每秒5万次激光脉冲在硅片上雕刻出0.13nm精度的电路&#xff08;相当于在月球表面精准定位一枚二维码&#xff09;&#xff0c;当国产28nm光刻机在华虹产线实现“从0到1”的突破&#xff0c;这场精密制造…