CSS position属性sticky实现吸顶菜单效果
zhezhongyun 2025-04-26 22:36 43 浏览
CSS的position属性用于指定元素在文档流中的定位方式,position属性和top、bottom、left、right属性一起决定元素的最终位置。position属性拥有static、relative、absolute、fixed、sticky五个可选项,下面动画展示了一个吸顶导航菜单的样式,当向上滚动页面时导航菜单始终黏在顶部位置,使用sticky属性可以轻松实现这个效果。
在正式引出sticky特性之前,有必要重新回顾下position各个属性的特征,真正理解了它们的含义用起来才会得心应手,出现问题也有清晰的思路去排查并解决它,而且理解sticky也依赖对其他属性的理解。
static是默认行为
该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。此时 top, right, bottom, left 和 z-index 属性无效。见下图黄色方框的位置,它所在的位置就是正常文档流应在的位置。
relative是相对原位置的偏移
该关键字下,元素先放置在未添加定位时的位置,在不改变页面布局的前提下调整元素位置。继续看黄色方框,假如仅仅设置position为relative的话,黄色方框的位置和static位置是一样的,也就是它按照正常文档流布局,但是此时top、left、right、bottom属性会改变黄色方框的位置,示例中黄色方框相对于原有位置向左、向下偏移了40px。
absolute是相对父级元素的偏移
元素会被移出正常文档流,并不为元素预留空间,通过指定元素相对于最近的非 static 定位祖先元素的偏移,来确定元素位置。包裹黄色方框的元素position被设置为relative,那么黄色方框就会依据其父级元素的位置为基准进行定位,示例中它相对于父级元素向左、向下偏移40px。
fixed是相对于视口的偏移
元素会被移出正常文档流,并不为元素预留空间,而是通过指定元素相对于屏幕视口(viewport)的位置来指定元素位置。下面的示例点击固定定位后,黄色方框移到了浏览器视口向左、向下40px的位置,且无论页面如何滚动,黄色框的位置始终和浏览器视口相对位置不变。
sticky是relative和fixed的结合体
最后,终于说到了ticky属性,它是relative和fixed属性的结合体,示例中黄色方框的样式设置为"position: sticky; top: 20px;",为了演示sticky的效果,将其上级元素设置了一个固定的高度并显示滚动条,当黄色方框与父元素的顶部高度大于20px时,它表现出relative的行为(也和static相似),正常布局到文档流中;当达到top为20px阈值之后,黄色方框始保持top=20px的位置,表现出黏在顶端的效果,此时表现出fixed的行为。
最后给出上面演示示例的完整源码,实际运行并点击每个选项实际体验一下,相信理解会更加深刻:
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>css position演示</title>
<style>
body {
font-size: larger;
}
.box {
float: left;
margin: 1rem;
width: 100px;
height: 100px;
border: 3px solid #00f;
background: rgba(0, 0, 255, .2);
}
#example-element {
border: 3px solid #f00;
background: rgba(255, 255, 0, .6);
}
#example-option {
display: flex;
flex-flow: column;
}
table {
border-collapse: collapse;
border: 1px solid gray;
}
td {
padding: 16px;
border-right: 1px solid gray;
}
button {
margin: 0.5rem;
padding: 1rem 2rem;
}
</style>
</head>
<body>
<h1>Position属性效果演示</h1>
<table>
<tr>
<td id="example-option">
<button onclick="updateStyle('static')">
默认定位 <br>
position: static;
</button>
<button onclick="updateStyle('relative')">
相对定位<br>
position: relative;
top: 40px; left: 40px;
</button>
<button onclick="updateStyle('absolute')">
绝对定位<br>
position: absolute;
top: 40px; left: 40px;
</button>
<button onclick="updateStyle('fixed')">
固定定位<br>
position: fixed;
top: 40px; left: 40px;
</button>
<button onclick="updateStyle('sticky')">
粘性定位<br>
position: sticky;
top: 20px;
</button>
</td>
<td id="output">
<div style="height: 452px;overflow: scroll;">
<div style="position: relative;">
<p>这个示例演示css position属性</p>
<br>
<br>
<br>
<div class="box"></div>
<div class="box" id="example-element"></div>
<div class="box"></div>
<p style="clear: left;">为了演示position: sticky效果</p>
<p>这里增加了一个可滚动的容器</p>
<p>上下滚动这段内容</p>
<p>你将发现黄色框会始终停留在视线范围内</p>
<p>就像黏在在顶部一样</p>
<p>重新向下滚动</p>
<p>黄色框还会恢复到原来的位置</p>
<p>使用sticky特性</p>
<p>可以实现很多特效</p>
<p>比如始终黏在顶部的菜单栏</p>
<p>发挥想象力还可以实现其他效果...</p>
</div>
</div>
</td>
</tr>
</table>
<script>
function updateStyle(position_mode) {
let box = document.getElementById("example-element")
if (position_mode == 'static') {
box.style = ""
} else if (position_mode == 'relative') {
box.style = "position: relative; top: 40px; left: 40px;"
} else if (position_mode == 'absolute') {
box.style = "position: absolute; top: 40px; left: 40px;"
} else if (position_mode == 'fixed') {
box.style = "position: fixed; top: 40px; left: 40px;"
} else if (position_mode == 'sticky') {
box.style = "position: sticky; top: 20px;"
}
}
</script>
</body>
</html>参考文献
[1]. https://developer.mozilla.org/zh-CN/docs/Web/CSS/position
相关推荐
- Python入门学习记录之一:变量_python怎么用变量
-
写这个,主要是对自己学习python知识的一个总结,也是加深自己的印象。变量(英文:variable),也叫标识符。在python中,变量的命名规则有以下三点:>变量名只能包含字母、数字和下划线...
- python变量命名规则——来自小白的总结
-
python是一个动态编译类编程语言,所以程序在运行前不需要如C语言的先行编译动作,因此也只有在程序运行过程中才能发现程序的问题。基于此,python的变量就有一定的命名规范。python作为当前热门...
- Python入门学习教程:第 2 章 变量与数据类型
-
2.1什么是变量?在编程中,变量就像一个存放数据的容器,它可以存储各种信息,并且这些信息可以被读取和修改。想象一下,变量就如同我们生活中的盒子,你可以把东西放进去,也可以随时拿出来看看,甚至可以换成...
- 绘制学术论文中的“三线表”具体指导
-
在科研过程中,大家用到最多的可能就是“三线表”。“三线表”,一般主要由三条横线构成,当然在变量名栏里也可以拆分单元格,出现更多的线。更重要的是,“三线表”也是一种数据记录规范,以“三线表”形式记录的数...
- Python基础语法知识--变量和数据类型
-
学习Python中的变量和数据类型至关重要,因为它们构成了Python编程的基石。以下是帮助您了解Python中的变量和数据类型的分步指南:1.变量:变量在Python中用于存储数据值。它们充...
- 一文搞懂 Python 中的所有标点符号
-
反引号`无任何作用。传说Python3中它被移除是因为和单引号字符'太相似。波浪号~(按位取反符号)~被称为取反或补码运算符。它放在我们想要取反的对象前面。如果放在一个整数n...
- Python变量类型和运算符_python中变量的含义
-
别再被小名词坑哭了:Python新手常犯的那些隐蔽错误,我用同事的真实bug拆给你看我记得有一次和同事张姐一起追查一个看似随机崩溃的脚本,最后发现罪魁祸首竟然是她把变量命名成了list。说实话...
- 从零开始:深入剖析 Spring Boot3 中配置文件的加载顺序
-
在当今的互联网软件开发领域,SpringBoot无疑是最为热门和广泛应用的框架之一。它以其强大的功能、便捷的开发体验,极大地提升了开发效率,成为众多开发者构建Web应用程序的首选。而在Spr...
- Python中下划线 ‘_’ 的用法,你知道几种
-
Python中下划线()是一个有特殊含义和用途的符号,它可以用来表示以下几种情况:1在解释器中,下划线(_)表示上一个表达式的值,可以用来进行快速计算或测试。例如:>>>2+...
- 解锁Shell编程:变量_shell $变量
-
引言:开启Shell编程大门Shell作为用户与Linux内核之间的桥梁,为我们提供了强大的命令行交互方式。它不仅能执行简单的文件操作、进程管理,还能通过编写脚本实现复杂的自动化任务。无论是...
- 一文学会Python的变量命名规则!_python的变量命名有哪些要求
-
目录1.变量的命名原则3.内置函数尽量不要做变量4.删除变量和垃圾回收机制5.结语1.变量的命名原则①由英文字母、_(下划线)、或中文开头②变量名称只能由英文字母、数字、下画线或中文字所组成。③英文字...
- 更可靠的Rust-语法篇-区分语句/表达式,略览if/loop/while/for
-
src/main.rs://函数定义fnadd(a:i32,b:i32)->i32{a+b//末尾表达式}fnmain(){leta:i3...
- C++第五课:变量的命名规则_c++中变量的命名规则
-
变量的命名不是想怎么起就怎么起的,而是有一套固定的规则的。具体规则:1.名字要合法:变量名必须是由字母、数字或下划线组成。例如:a,a1,a_1。2.开头不能是数字。例如:可以a1,但不能起1a。3....
- Rust编程-核心篇-不安全编程_rust安全性
-
Unsafe的必要性Rust的所有权系统和类型系统为我们提供了强大的安全保障,但在某些情况下,我们需要突破这些限制来:与C代码交互实现底层系统编程优化性能关键代码实现某些编译器无法验证的安全操作Rus...
- 探秘 Python 内存管理:背后的神奇机制
-
在编程的世界里,内存管理就如同幕后的精密操控者,确保程序的高效运行。Python作为一种广泛使用的编程语言,其内存管理机制既巧妙又复杂,为开发者们提供了便利的同时,也展现了强大的底层控制能力。一、P...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML文本框样式 (31)
- HTML滚动条样式 (34)
- HTML5 浏览器支持 (33)
- HTML5 新元素 (33)
- HTML5 WebSocket (30)
- HTML5 代码规范 (32)
- HTML5 标签 (717)
- HTML5 标签 (已废弃) (75)
- HTML5电子书 (32)
- HTML5开发工具 (34)
- HTML5小游戏源码 (34)
- HTML5模板下载 (30)
- HTTP 状态消息 (33)
- HTTP 方法:GET 对比 POST (33)
- 键盘快捷键 (35)
- 标签 (226)
- opacity 属性 (32)
- transition 属性 (33)
- 1-1. 变量声明 (31)
