CSS 定位的核心属性:position

🧩 一、CSS 定位的核心属性:position

position 属性用于定义一个元素在页面中的定位方式,它决定了:

  • 元素在页面中的定位规则
  • 是否脱离文档流
  • 元素的位置是相对于谁(父元素、浏览器窗口、自身等)

✅ 可选值如下:

名称是否脱离文档流定位参考说明
static静态定位​(默认值)❌ 不脱离元素按照正常的文档流排列,​top、right、bottom、left、z-index 无效
relative相对定位❌ 不脱离元素自身原本的位置相对于元素原本应该放置的位置进行偏移,但仍占据原来的空间
absolute绝对定位✅ 脱离最近的已定位(非 static)祖先元素,如果没有则相对于 <html>(视口)脱离文档流,相对于定位了的父级定位,常用于弹窗、下拉菜单等
fixed固定定位✅ 脱离浏览器视口(viewport)​相对于浏览器窗口固定,​滚动时位置不变,常用于导航栏、回到顶部按钮
sticky粘性定位⚠️ 特殊(介于相对与固定之间)视口 + 滚动容器在屏幕范围内表现为 relative,超出后表现为 fixed,常用于吸顶导航

🧠 二、各定位属性详解与示例


1️⃣ position: static —— ​静态定位(默认)​

✅ 说明:
  • 默认值,即如果你不写 position,元素就是 static
  • 元素按照 ​正常的文档流​ 排列(从上到下、从左到右)。
  • ​**toprightbottomleft 和 z-index 属性无效!​**​
📌 示例: 
div.static-box {position: static; /* 默认值,可省略 */background: lightblue;
}
<div class="static-box">我是静态定位(默认)</div>

🎯 你几乎不需要主动设置 position: static,因为这就是默认行为。


2️⃣ position: relative —— ​相对定位

✅ 说明:
  • 元素依然在正常的文档流中,​占用原本的空间
  • 但你可以通过 toprightbottomleft 将它相对于它自身本来的位置进行偏移
  • 常用于作为 ​**absolute 定位的参考父级**​(即给子元素提供定位上下文)。
📌 示例:
div.relative-box {position: relative;top: 20px;left: 30px;background: lightcoral;
}
<div class="relative-box">我相对自己原本位置,向下 20px,向右 30px</div>

🎯 虽然它移动了位置,但它原来占的空间还在,不影响其他元素的布局。


3️⃣ position: absolute —— ​绝对定位

✅ 说明:
  • 脱离文档流,​不占据原来的空间,其他元素会无视它的存在。
  • 它的位置是相对于最近的一个定位祖先(即 position 不是 static 的祖先)​进行定位的。
  • 如果没有定位的祖先,则相对于 <html>(即整个浏览器窗口)定位。
📌 常见用途:
  • 弹出框、下拉菜单、提示框、自定义 tooltip
  • 需要精准控制位置的 UI 元素
📌 示例:
<div class="parent"><div class="absolute-box">我是绝对定位</div>
</div>
.parent {position: relative; /* 作为 absolute 定位的参考 */height: 200px;background: #eee;
}.absolute-box {position: absolute;top: 50px;left: 50px;background: lightgreen;
}

✅ .absolute-box 是相对于 .parent(它最近的 ​非 static 定位的父级)进行定位的。

🔒 ​注意:​

如果父级都没有设置 position: relative / absolute / fixed,那么绝对定位的元素会相对于 <html>(整个页面)定位。


4️⃣ position: fixed —— ​固定定位

✅ 说明:
  • 脱离文档流
  • 相对于浏览器视口(viewport)进行定位,​滚动页面时位置固定不变
  • 常用于:导航栏、返回顶部按钮、悬浮客服等
📌 示例:
.fixed-box {position: fixed;bottom: 20px;right: 20px;background: gold;padding: 10px;
}
<div class="fixed-box">我永远固定在右下角</div>

✅ 无论你如何滚动页面,这个 DIV 始终停留在浏览器窗口的 ​右下角

🔧 常见应用场景:

  • 回到顶部按钮
  • 悬浮购物车
  • 侧边栏导航
  • 吸底客服

5️⃣ position: sticky —— ​粘性定位

✅ 说明:
  • 特殊定位​:它**在屏幕内时表现为 relative,超出屏幕(滚动到某位置后)时表现为 fixed**​
  • 常用于:​吸顶导航、表格头部固定
  • 它需要至少一个方向上设置 topbottomleft 或 right,否则不生效!
📌 示例:吸顶效果
.sticky-header {position: sticky;top: 0; /* 当滚动到距离视口顶部为 0 时固定 */background: lightblue;z-index: 100;
}
<div class="sticky-header">我是粘性定位(滚动到顶部时会吸住)</div>
<!-- 很多内容... -->

✅ 当页面向下滚动,这个元素会在到达视口顶部时“粘”在顶部不动,就像导航栏一样。
它在没到达那个位置之前,仍然正常地在文档流里。

🔒 ​注意:​

  • 必须指定 topbottomleft 或 right 中的一个,否则不生效!
  • 父容器不能有 overflow: hidden,否则可能失效

🧩 三、定位相关的重要属性

在使用 position 定位时,通常还会配合以下属性来精确定位元素:

属性说明示例
top距离上边的距离top: 10px;
right距离右边的距离right: 20px;
bottom距离下边的距离bottom: 30px;
left距离左边的距离left: 40px;
z-index控制元素的堆叠顺序(层级)z-index: 10;,数值越大越靠前

⚠️ 注意:z-index ​只在定位元素(非 static)上才生效!​


🧠 四、定位方式对比总结表

定位类型是否脱离文档流定位参考是否可用 top/left 等典型用途
静态定位static❌ 不脱离❌ 无效默认布局,正常文档流
相对定位relative❌ 不脱离元素自身原位置✅ 可用微调元素位置,作为 absolute 的参考父级
绝对定位absolute✅ 脱离最近的定位祖先(或 html)✅ 可用弹窗、下拉菜单、tooltip
固定定位fixed✅ 脱离浏览器视口(viewport)✅ 可用回到顶部、导航栏、悬浮按钮
粘性定位sticky⚠️ 特殊视口 + 滚动容器✅ 可用(需 top 等)吸顶导航、表格固定头部

✅ 五、总结一句话

CSS 的 position 属性用于控制元素的定位方式,包括 static(默认)、relative(相对)、absolute(绝对)、fixed(固定)、sticky(粘性)。不同的定位方式决定了元素是否脱离文档流、相对于谁定位,以及如何精准控制其在页面中的位置,是实现复杂布局和交互效果的核心机制。​

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

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

相关文章

数据结构之深入探索快速排序

基准值的选定 我们之前已经用四种不同的方式实现了快速排序&#xff0c;如果还没有学习过的伙伴们可以看一下这篇文章哦&#xff1a;数据结构之排序大全&#xff08;3&#xff09;-CSDN博客 那我们既然已经学习了这么多种方法&#xff0c;为什么还要继续探索快速排序呢&#…

《递归与迭代:从斐波那契到汉诺塔的算法精髓》

&#x1f525;个人主页&#xff1a;艾莉丝努力练剑 ❄专栏传送门&#xff1a;《C语言》、《数据结构与算法》、C语言刷题12天IO强训、LeetCode代码强化刷题、洛谷刷题、C/C基础知识知识强化补充、C/C干货分享&学习过程记录 &#x1f349;学习方向&#xff1a;C/C方向学习者…

《LINUX系统编程》笔记p3

可重用函数不使用全局部变量&#xff0c;可以重复使用的函数.stat 命令作用&#xff1a;显示一个文件或文件夹的“元信息”。文件基本信息文件&#xff08;File&#xff09;&#xff1a;显示所查询对象的名称。大小&#xff08;Size&#xff09;&#xff1a;文件的大小&#xf…

大模型0基础开发入门与实践:第3章 机器的“统计学”:机器学习基础概念扫盲

第3章 机器的“统计学”&#xff1a;机器学习基础概念扫盲 1. 引言 想象一下&#xff0c;你是一位古代的农夫&#xff0c;毕生的经验告诉你&#xff1a;乌云密布、燕子低飞&#xff0c;那么不久便会下雨。你并没有学习过气象学&#xff0c;也不懂大气压和水汽凝结的原理。你的“…

Java调用Ollama(curl方式)

1. 安装Ollama Search 2. 调用 相关依赖 <dependencies><dependency><groupId>org.apache.httpcomponents</groupId><artifactId>httpclient</artifactId><version>4.5.14</version></dependency><dependency>&…

nodejs koa框架使用

1: KOA 是express 打造的下一代web 开发框架提供更小更强的的核心功能&#xff0c;通过Promise 、async/await 进行异步编程&#xff0c;koa 可以不使用回调&#xff0c;解决了回调地狱的问题 blueBird 是nodejs 最出名的Primise 实现&#xff0c;除了实现标准的promise 之外&a…

2025年图像处理与光学国际会议(ICIPO 2025)

2025年图像处理与光学国际会议&#xff08;ICIPO 2025&#xff09; 2025 International Conference on Image Processing and Optics一、大会信息会议简称&#xff1a;ICIPO 2025 大会地点&#xff1a;中国北京 审稿通知&#xff1a;投稿后2-3日内通知 投稿邮箱&#xff1a;iac…

Kubernetes 构建高可用、高性能 Redis 集群

k8s下搭建Redis高可用1. 部署redis服务创建ConfigMap创建 Redis创建 k8s 集群外部2. 创建 Redis 集群自动创建 redis 集群手动创建 redis 集群验证集群状态3. 集群功能测试压力测试故障切换测试4. 安装管理客户端编辑资源清单部署 RedisInsight控制台初始化控制台概览实战环境使…

文件IO的基础操作

Java针对文件进行的操作:文件系统操作,File类(file类指定的路径,可以是一个不存在的文件)文件内容操作 : 流对象分为两类(1)字节流 以字节为基本的读写单位的 二进制文件 InputStream OutputStream(2)字符流 以字符为基本的读写单位的 …

【模版匹配】基于深度学习

基于深度学习的模版匹配 概述 本报告整理了2024-2025年最新的、可直接使用的模板匹配相关论文、方法和开源代码实现。所有方法都提供了完整的代码实现和预训练模型&#xff0c;可以直接应用到实际项目中。 一、轻量级现代模板匹配框架 1.1 UMatcher - 4M参数的紧凑型模板匹…

CMake进阶:Ninja环境搭建与加速项目构建

目录 1.引入Ninja的原因 2.Ninja 环境搭建&#xff08;跨平台&#xff09; 2.1.Linux系统安装 2.2.macOS 系统 2.3.Windows 系统 2.4.源码编译安装&#xff08;通用方案&#xff09; 3.Ninja 与构建系统配合&#xff1a;以 CMake 为例 4.加速构建的关键技巧 5.Ninja 与…

开发避坑指南(35):mybaits if标签test条件判断等号=解析异常解决方案

异常信息 org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibatis.builder.BuilderException: The expression orderInfo.idList evaluated to a null value.报错语句 <if test"orderInfo.queryFlag ! null and orderInfo.queryFlag sett…

GitCode 疑难问题诊疗:全面指南与解决方案

引言 在软件开发的动态领域中&#xff0c;GitCode 作为一款强大的分布式版本控制系统&#xff0c;已然成为团队协作与项目管理的基石。它赋予开发者高效管理代码版本、轻松实现并行开发以及顺畅协同合作的能力。然而&#xff0c;如同任何复杂的技术工具&#xff0c;在 GitCode…

使用 JS 渲染页面并导出为PDF 常见问题与修复

本文直击两个最常见的导出痛点&#xff0c;并给出可直接落地的诊断 修复方案&#xff08;适用于 html2canvas jsPDF ECharts/自绘 canvas 场景&#xff09;。 问题清单 问题 A&#xff1a;导出后图表模糊&#xff0c;线条与文字不清晰&#xff08;低分辨率&#xff09;。问题…

【Java后端】【可直接落地的 Redis 分布式锁实现】

可直接落地的 Redis 分布式锁实现&#xff1a;包含最小可用版、生产可用版&#xff08;带 Lua 原子解锁、续期“看门狗”、自旋等待、可重入&#xff09;、以及基于注解AOP 的无侵入用法&#xff0c;最后还给出 Redisson 方案对比与踩坑清单。一、设计目标与约束 获取锁&#x…

数据结构 -- 链表--双向链表的特点、操作函数

双向链表的操作函数DouLink.c#include "DouLink.h" #include <stdio.h> #include <stdlib.h> #include <string.h>/*** brief 创建一个空的双向链表* * 动态分配双向链表管理结构的内存&#xff0c;并初始化头指针和节点计数* * return 成功返回指…

Wireshark获取数据传输的码元速率

一、Wireshark的物理层参数 Wireshark主界面可以看到数据发送时刻和长度&#xff1a; 这个时刻是Wireshark完整获取数据包的时刻&#xff0c;实际上就是结束时刻。 需要知道的是&#xff1a; Wireshark工作在数据链路层及以上&#xff0c;它能解码 以太网帧 / IP 包 / TCP…

11.1.3 完善注册登录,实现文件上传和展示

1、完善注册/登录 1. 涉及的数据库表单&#xff1a;user_info 2. 引用MySQL线程池&#xff0c;Redis线程池 3. 完善注册功能 4. 完善登录功能 2.1 涉及的数据库表单&#xff1a;user_info 重新创建数据库 #创建数据库 DROP DATABASE IF EXISTS 0voice_tuchuang;CREATE D…

【Linux文件系统】目录结构

有没有刚进入Linux世界时&#xff0c;对着黑乎乎的终端&#xff0c;输入一个 ls / 后&#xff0c;看着蹦出来的一堆名字 like bin, etc, usr&#xff0c;感觉一头雾水&#xff0c;像是在看天书&#xff1f; 别担心&#xff0c;你不是一个人。Linux的文件系统就像一个超级有条理…

螺旋槽曲面方程的数学建模与偏导数求解

螺旋槽曲面的数学描述 在钻头设计和机械加工领域,螺旋槽的几何建模至关重要。螺旋槽通常由径向截形绕轴做螺旋运动形成,其数学模型可通过参数方程和隐函数方程两种方式描述。 设螺旋槽的径向截形方程为: y=f(z)y = f(z)y=f(z) x=xcx = x_cx=xc​ 其中 xcx_cxc​ 为常数,…