百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

CSS中的定位(postion)详解

qiyuwang 2025-05-16 15:45 3 浏览 0 评论

定义

CSS position属性用于指定一个元素在文档中的定位方式。top,right,bottom 和 left 属性则决定了该元素的最终位置,z-index属性则决定了该元素所在的层级。

定位类型

1. static: 静态定位(默认值),元素出现在正常的文档流中(元素的top,left,bottom,right以及z-index声明无效)。

2. relative:相对定位,即元素相对于自身的位置进行定位,可以理解为元素相对自身的位置设置相应的偏移量(top, lefft等值)。

.element {

position: relative;

top: 100px;

left: 50px;

}

在上述例子中,元素element 会相对于自身位置发生向下100px,向右50px的偏移。

3. absolute:绝对定位,即元素的位置相对于祖先元素中第一个非静态定位的元素的位置定位。绝对定位元素会被移出正常文档流。

.parent {

position: relative;

width: 100%;

height: 500px;

.element {

position: absolute;

top: 100px;

left: 0;

}

}

在上述例子中,元素element 始终固定在父元素的top:100px, left: 0的位置。

4. fixed: 固定定位,即元素的位置相对于浏览器的窗口进行定位。但是,当父级元素追踪设置了transform属性并且值不为none时,子元素的position: fixed就会失效。这是因为,**当元素祖先的 transform 属性非 none 时,定位容器由视口改为该祖先**。固定定位元素会被移出正常文档流。

.element {

position: fixed;

top: 100px;

left: 100px;

}

在上述例子中,元素element 始终固定在相对于浏览器视口的top: 100px, left: 100px位置。

5. inherit: 规定应该从父元素继承 position 属性的值。

6. sticky: 粘性定位,即元素相对于父元素的定位定位。一个sticky元素会“固定”在离它最近的一个拥有“滚动机制”的祖先上。必须指定 top, right, bottom 或 left 四个属性中的其中一个,粘性定位才会生效。否则其行为与相对定位相同。且元素不会脱离文档流,该值总是创建一个新的层叠上下文(stacking context)。

.parent {

width: 100%;

height: 500px;

overflow: auto;

.element {

position: sticky;

position: -webkit-sticky;

top: 100px;

left: 0;

}

}

在上述例子中,元素element 始终会固定在父元素的top为100px,left为0px的位置,直到 viewport 视口回滚到阈值以下。

兼容性

![sticky兼容性](
https://upload-images.jianshu.io/upload_images/23997970-f0d13d8f0de42b9e.png?
imageMogr2/auto-orient/strip%7CimageView2/2/w/1240)

Internet Explorer, Edge 15 及更早 IE 版本不支持 sticky 定位。 Safari 需要使用 -webkit- prefix 。目前在sticky属性对各大浏览器都都比较友好的支持,但是在table(thead, tr)中仍然存在一下bug。

已知bugs:

  • 在safari中,父元素设置 `overflow: auto`, 将会使sticky失效
  • Firefox 58及以下版本,Chrome 63及以下版本和Safari 7及以下版本似乎不支持粘性表格标题。

并且,在小程序中,你仍然可以使用sticky属性,这在封装导航组件时非常有用



本为已同步到个人博客网站, 更好的阅读体验,请打开
https://www.gogoing.site/index.html

相关推荐

你们想要的Python爬虫教程来了:从原理到实践

概述:网络世界的智能采集者Python爬虫是通过自动化程序模拟人类浏览网页行为的技术工具,其核心价值在于高效获取并解析网络数据。得益于Python丰富的第三方库(如requests、Beautiful...

你需要知道的 19 个 console 实用调试技巧

大家好,我是Echa。之前给大家介绍了《...

CSS布局必备技能

Flex是一种用于布局的CSS属性,它使得在容器中的子元素能够灵活地伸缩和排列,从而实现更加自适应和响应式的布局。使用Flex布局可以轻松地创建各种复杂的布局,而无需使用复杂的CSS或者...

我是如何使用ChatGPT和CoPilot作为编码助手的

...

jsoup Selector类学习笔记,快速提升你的HTML处理能力!

Selector类是jsoup库中的一个核心类,用于通过CSS选择器语法来查找HTML文档中的元素。选择器语法通用选择器*:匹配任何元素。标签选择器tag:匹配指定标签名的元素。...

CSS伪类选择器大全:提升网页交互与样式的神奇工具

CSS伪类选择器是前端开发中不可或缺的强大工具,它们允许我们根据元素的状态、位置或用户行为动态地应用样式。本文将全面介绍常用的伪类选择器,并通过代码示例展示其实际应用场景。一、基础交互伪类1.超链接...

简析JS中Document与CSS

如果你是一名前端人员,你单单的使用jq插件显然不够,js在大多时候比较搁置,但你如果前端技术想要提升,那么js的精通对你显得很重要,本文只是他到js的document与css。1.Document与E...

网页世界隐藏的神秘代码语言,竟能这样改变布局

CSS基础:选择器与属性CSS(CascadingStyleSheets)是用于控制网页外观的一门样式表语言。它通过定义HTML元素的显示方式来增强网页的表现力。CSS的选择器允许开发者精确地定位...

Thymeleaf 语法全面详解(史上最全)

Thymeleaf是一个现代化的服务器端Java模板引擎,支持HTML、XML、JavaScript、CSS甚至纯文本。以下是Thymeleaf语法的全面详解,包含所有属性和复杂用法。...

零基础学习HTML之CSS篇内联内部外部样式表和类型选择符

CSS简介CSS(CascadingStyleSheets)层叠样式表。CSS能做些什么?1.使用CSS样式可以有效地对页面进行布局。2.使用CSS样式可以对页面字体、颜色、背景和其他效果实现...

css 设置盒子阴影,阴影和背景图保持一致

预览图首先查看预览图:原理采用了background属性...

CSS中的定位(postion)详解

定义CSSposition属性用于指定一个元素在文档中的定位方式。top,right,bottom和left属性则决定了该元素的最终位置,z-index属性则决定了该元素所在的层级。定位类型1...

CSS selector 小知识学习分享

在设计器中,大家拾取网页元素后,在右侧的属性栏里都会有一个叫“查找路径”的选择框,一般也很少有人用到,打开后里面显示了一堆‘@#yen#%#yen@*T&’的玩意,那么这个“查找路径”到底是个什...

从网站检查中复制CSS代码的最简单方法

在处理网站项目时,您是否曾经对使用开发工具感到沮丧?必须在您正在处理的网页和检查器之间来回切换以查看CSS并进行调整通常可能是一个挑战。值得庆幸的是,有一个浏览器扩展程序可以简化该过程:CSSSca...

XPath 选择器

上篇《Selenium入门(基于Python)...

取消回复欢迎 发表评论: