CSS position属性sticky实现吸顶菜单效果
zhezhongyun 2025-04-26 22:36 22 浏览
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
相关推荐
- Win10全新版本速览 全新图标设计焕然一新
-
来源:太平洋电脑网[PConline资讯]原定于今年下半年发布的Win1021H2(SunValley),再有几个月就要与我们见面了。之前我们已经陆续介绍过新版在开始菜单、窗口动效、通知中心等方...
- 第四周B组最佳选手Icon:陨落天团的小将,还是重生星球的偶像?
-
B组本来被认为是死亡之组,但在上周的异组对抗赛中,实力较强的几只队伍却先后被A组击沉,反而是之前一分难求的OMG2:1战胜了IG,其中Icon功不可没,两次秀翻全场的妖姬和与Juejue中野联动的实力...
- 系统小技巧:不花一分钱 让声音再大些
-
有时,笔记本扬声器的音量可能无法满足我们对声音播放的需求。点击系统托盘的小喇叭图标,音量调节滑动条调整到最大也无效,而添置大功率扬声器又不是我们所愿。这时,可通过调整系统本身的设置或利用第三方软件来解...
- DNF手游:70级毕业搭配曝光!需集齐四类装备,别指望无形升级了
-
随着dnf手游7.16版本的临近,各种70级装备的消息满天飞,真真假假难以辨别,但只要以“发布会爆料”为核心,主播十四的爆料为辅,就能确定70版本的毕业标准搭配,查理策划是打算“集百家之长”于一身,完...
- 学会这5个电脑设置 可解决99%的故障
-
现阶段复工大家都是宅家办公吧,所以电脑可谓是大救星,因为无论是“停课不停学”的网课,还是在家办公的穷社畜,都离不开电脑。所以今天小编就来教大家几招电脑的自救方法,让你可以在电脑出问题时从容面对,足不出...
- LOL:上单腕豪的取胜之道——掌控自身优势,融合装备特效
-
01前言腕豪这个英雄,在11.9版本之前都没有太多的出场机会,即使出现也大多是在辅助位置上,充当开团、先手控制的角色。但是在11.9版本以后,这个英雄突然之间仿佛飞升了一般,直接冲上T1级别上单,之前...
- 英雄联盟手游:一篇文章读懂所有龙buff属性效果,还不赶紧收藏
-
英雄联盟手游采用也是经典峡谷地图,看起来和端游并没有太大差异,但实际上为了适应手游节奏,官方也是进行了适当调整,所以包括红蓝buff,大龙小龙buff效果会有一定的差异,现在就来看看小龙和大龙具体属性...
- 双击打不开怎么办?双击文件夹显示属性的解决办法
-
今天小编在双击文件夹的时候,就是打不开,还弹出“属性”对话框,不知道大家有没有出现过,为避免出现这种情况时大家束手无策,今天小编就来为大家分享一下解决方法。1.检查键盘,看看“Alt”键是否卡住。由于...
- 柜子布局好超省空间,1㎡当10㎡用,收纳涨5倍!户型图直接抄
-
柜子不嫌多,就怕你家放不下!▼每个空间几乎都需要柜子客厅要有电视柜,卧室要能放下全家四季的衣柜,厨房还需要大容量的橱柜空间就这么小,想要榨出放柜子的地方,还要活得不拥挤简直太难了!其实全是你找错地方打...
- 制作幻灯片的另类方法(然后制作幻灯片)
-
如果提到制作幻灯片,很多人都会想到PowerPoint。PowerPoint提供了很多模板,但这些模板实用性并不太高;PowerPoint的交互还算比较方便,但不可否认,交互显得有些呆板,而且要想修改...
- 《心灵杀手重制版》画面晃动怎么办?画面晃动解决办法
-
针对《心灵杀手重制版》画面晃动的问题,以下是一些解决办法:修改游戏启动路径:打开游戏所在的文件夹,找到游戏图标的属性并打开。在属性中修改启动路径,加入“-noblur”参数。例如,如果游戏安装在“X:...
- win10网络图标是小地球怎么办(excel表格怎样选定区域打印)
-
win10系统右下角的网络图标突然变成地球图标,而且无法上网,提示无法连接到Internet。出现这个问题多数是因为win10正式版更新了或者是网络中断后遗症。那么win10网络图标变成地球怎么办呢?...
- 重看电脑任务栏的使用方法:windows 10小贴士
-
【环球科技综合报道】据日本Livedoor新闻网2月18日报道,windows电脑的屏幕下方配置的任务栏由于总是在电脑桌面上显示,可以说是一个映入眼帘的机会格外多的区域。像是把经常使用的软件图标设置在...
- 《地狱之门》攻略:四大元素属性介绍
-
《地狱之门》是近期比较看好的一款卡牌手游,绚丽的3D游戏画面以及创新的即时战斗系统给人耳目一新的感觉,非常值得一试。玩家不仅可以体验到卡牌收集的乐趣,更主要的是能体验到酣畅淋漓的战斗体验。下面小编就来...
- 一脸懵?DNF希洛克词条赋予属性触发条件解析
-
DNF希洛克已经开放两天,但是还是看到不少小伙伴对于希洛克词条赋予系统充满疑惑。今天就来简单易懂的给大家科普一下希洛克词条赋予系统里的弯弯绕绕。◎希洛克装备融合在希洛克获取了专属史诗之后,即可通过歌兰...
- 一周热门
- 最近发表
- 标签列表
-
- HTML 教程 (33)
- HTML 简介 (35)
- HTML 实例/测验 (32)
- HTML 测验 (32)
- JavaScript 和 HTML DOM 参考手册 (32)
- HTML 拓展阅读 (30)
- HTML常用标签 (29)
- 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)
- HTML button formtarget 属性 (30)
- CSS 水平对齐 (Horizontal Align) (30)