0

0

CSS 定位 – 绝对、相对、固定和粘性

PHPz

PHPz

发布时间:2024-09-10 10:30:45

|

790人浏览过

|

来源于dev.to

转载

css 定位 – 绝对、相对、固定和粘性

第 11 讲:css 定位 – 绝对、相对、固定和粘性

欢迎来到《从基础到辉煌》课程第十一讲。在本次讲座中,我们将探讨css定位的不同类型:相对绝对固定粘性。了解定位可以让您控制元素在页面上的显示位置以及用户与内容交互时元素的行为方式。


1.了解位置属性

position 属性指定元素在文档中的位置。它可以采用以下值:

  • 静态:默认值。元素根据正常文档流定位。
  • 相对:元素相对于其正常位置定位。
  • 绝对:元素相对于其最近的定位祖先或初始包含块进行定位。
  • 固定:元素相对于浏览器窗口定位,并在滚动时保持在相同位置。
  • 粘性:元素被视为相对元素,直到达到阈值(例如滚动位置),然后它变得固定。

2.相对定位

具有position:relative的元素相对于其原始(静态)位置定位。它保留在文档流中,这意味着其他元素仍会考虑它。

  • 示例:使用相对定位来移动元素。
  .box {
    position: relative;
    top: 20px; /* moves the box 20px down from its normal position */
    left: 30px; /* moves the box 30px to the right */
  }

在此示例中,元素从原始位置向下移动 20px,向右移动 30px,但保留其在文档流中的空间。

立即学习前端免费学习笔记(深入)”;


3.绝对定位

位置为绝对的元素将从文档流中删除,并相对于其最近的定位祖先(即位置不是静态的祖先)进行定位。

  • 示例:将元素绝对定位在容器内。
  .container {
    position: relative; /* this container is the reference for the absolute positioning */
    width: 300px;
    height: 200px;
    background-color: #f4f4f4;
  }

  .box {
    position: absolute;
    top: 50px;
    right: 20px;
    background-color: #333;
    color: white;
    padding: 10px;
  }

在此示例中:

Delphi 实例精选全掌握 CHM
Delphi 实例精选全掌握 CHM

来自万一的DELPHI编程博客,精品经验和实战的结晶,感谢万一的无私奉献,相信对DELPHI编程的朋友绝对有用处。CHM内的大部分源码在D7下全部编译通过,而且很少使用第三方控件,是学习的精品。 注:如果电子书不能正常显示,需要点击电子书“属性”->“解除锁定”就可以了。

下载
  • .box 绝对位于距离顶部 50 像素、距离右侧 20 像素 .container 元素内部。
  • .container 具有position:relative,使其成为.box 的定位参考。

4.固定定位

位置为固定的元素相对于浏览器窗口定位,无论页面如何滚动。

  • 示例:创建固定导航栏。
  .navbar {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    background-color: #333;
    color: white;
    padding: 15px;
    text-align: center;
  }

在此示例中:

  • .navbar 位于视口顶部,即使页面滚动也保持固定。

5.粘性定位

具有position: sticky 的元素被视为相对元素,直到用户滚动超过定义的阈值,此时它变得固定。

  • 示例:滚动后保留在顶部的粘性标题。
  .header {
    position: sticky;
    top: 0;
    background-color: #333;
    color: white;
    padding: 10px;
  }

在此示例中:

  • .header 的行为就像普通元素一样,直到它到达页面顶部。之后,它会粘在顶部并在用户滚动时保持可见。

6. z-索引

当元素被定位(相对、绝对、固定或粘性)时,您可以使用 z-index 属性控制它们的堆叠顺序。较高的 z-index 值使元素出现在较低的元素之上。

  • 示例:控制堆叠顺序。
  .box1 {
    position: absolute;
    top: 50px;
    left: 50px;
    z-index: 1; /* lower z-index */
    background-color: #f4f4f4;
    padding: 20px;
  }

  .box2 {
    position: absolute;
    top: 80px;
    left: 80px;
    z-index: 2; /* higher z-index */
    background-color: #333;
    color: white;
    padding: 20px;
  }

在此示例中:

  • 由于 z-index 值较高,.box2 将出现在 .box1 上方。

7.结合定位技术

您可以组合定位值来创建高级布局。

  • 示例:修复了具有相对内容区域的侧边栏。
  .sidebar {
    position: fixed;
    top: 0;
    left: 0;
    width: 200px;
    height: 100vh;
    background-color: #333;
    color: white;
    padding: 20px;
  }

  .content {
    position: relative;
    margin-left: 220px; /* Account for the fixed sidebar */
    padding: 20px;
  }

在此布局中:

  • .sidebar 固定在页面左侧并在滚动时保持可见。
  • .content 区域相对定位并调整其边距以适应侧边栏。

练习运动

  1. 创建一个具有固定页眉和页脚的网页,并对内容使用相对和绝对定位。
  2. 添加滚动时固定的粘性侧边栏。

下一步:在下一堂课中,我们将深入探讨css 变换和动画,您将在其中学习如何轻松为 web 元素设置动画。准备好让您的设计充满活力和互动!


在 linkedin 上关注我
里多伊·哈桑

相关专题

更多
css
css

css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。

524

2023.06.15

css居中
css居中

css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。

268

2023.07.27

css如何插入图片
css如何插入图片

cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

761

2023.07.28

css超出显示...
css超出显示...

在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。

539

2023.08.01

css字体颜色
css字体颜色

CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。

761

2023.08.10

什么是css
什么是css

CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。

606

2023.08.10

css三角形怎么写
css三角形怎么写

CSS可以通过多种方式实现三角形形状,本专题为大家提供css三角形怎么写的相关教程,大家可以免费体验。

561

2023.08.21

css设置文字颜色
css设置文字颜色

CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。

397

2023.08.22

c++空格相关教程合集
c++空格相关教程合集

本专题整合了c++空格相关教程,阅读专题下面的文章了解更多详细内容。

0

2026.01.23

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Sass 教程
Sass 教程

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3万人学习

CSS教程
CSS教程

共754课时 | 23.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号