粘性定位------------------position:sticky

本文探讨CSS的position:sticky属性在iOS Safari中的支持和安卓上的限制。总结了使sticky生效的四个关键条件:父级高度大于sticky元素高度、sticky元素不与父级底部重叠、父级不能有overflow隐藏属性、需设置top或bottom属性。注意,sticky元素只在其父容器内有效。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

position:sticky---------------------用这个属性,主要是ios下的safari已经支持了,在ios下可以免去js模拟,效果更平滑;安卓的话暂时不要考虑了


关于这个position:sticky的介绍,可以google一下,网上有很多介绍了 。

在这简述一下:

position: sticky,自IOS 6.1就支持了,最近Chrome56才支持没有滚过初始位置时,和position: relative表现类似(占据空间,!static能为后代元素提供定位参照),但topleft无效滚过初始位置时,和position: fixed表现类似,topleft生效,固定在屏幕可见区域,但页面不会抖动原本占据的空间还在(自带守家占位符的感觉)。

今天主要讲的是,position:sticky的使用条件,很多同学经常遇到position:sticky失效的情况,今天对sticky这个属性做了一番调试,总结了一些规律。现分享下。

俗话说,弄不清楚原理,就熟记结论也是一样的,那就抛出结论,sticky满足以下条件才能生效:

1、具有sticky属性的元素,其父级高度必须大于sticky元素的高度。

2、sticky元素的底部,不能和父级底部重叠。(这条不好表述,文后详细说明)

3、sticky元素的父级不能含有overflow:hidden 和 overflow:auto 属性

4、必须具有top,或 bottom 属性。

同时要注意,sticky元素仅在他父级容器内有效,超出容器范围则不再生效了。

如果遇到类似问题(要亲手测试查验)


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值