深入理解position sticky 粘性定位

粘性定位可以被认为是相对定位和固定定位的混合(即元素子再跨越特定阈值前为相对定位,之后为固定定位)

粘性定位可以被认为是相对定位和固定定位的混合(即元素子再跨越特定阈值前为相对定位,之后为固定定位)

基本概念

  • 流盒
    指的是粘性定位元素最近的可滚动元素(overflow属性值不是visible的元素)的尺寸盒子,如果没有可滚动元素,则表示浏览器视窗盒子。
  • 粘性约束矩形
    即粘性布局元素的父级元素矩形

特性

  • 当粘性约束矩形在可视范围内为relative,反之,则为fixed
  • 粘性定位元素如果和它的父元素一样高,则垂直滚动的时候,粘性定位效果是不会出现的
  • 它的定位效果完全受限于父级元素们。如果父元素的overflow属性设置了scroll,auto,overlay值,那么,粘性定位将会失效
  • 同一容器中多个粘贴定位元素独立偏移,因此可能重叠;位置上下靠在一起的不同容器中的粘贴定位元素则会鸠占鹊巢,挤开原来的元素,形成依次占位的效果。

应用场景:

1、粘性定位常作用在导航和概览信息(标题,表头,操作栏,底部评论等)上

2、当用户在浏览详细信息时,也能看到信息的概览和做一些操作,给用户带来便捷的使用体验。

粘性定位的原理:

1、要理解粘性定位元素,首先我们要知道这几个名词概念:视口元素,容器元素,粘性约束元素 和 sticky 元素

视口元素:显示内容的区域。会设置宽,高。一般会设置 overflow:hidden

容器元素:离 sticky 元素最近的能滚动的祖先元素。

粘性约束元素:粘性定位的父元素。有时,也会出现粘性约束元素就是容器元素的情况。

sticky 元素:设置了 position: sticky; 的元素。

2、滚动时,sticky 元素设置的 left, right, top, bottom 的值相对的是容器元素。当粘性约束元素滚出视口时,sticky 元素也会滚出视口。

粘性定位不生效的情况:

情况1: 未指定 left, right, top 和 bottom 中的任何一个值

设置 position: sticky相当于设置position: relative。

必须要指定 left, right, top 或 bottom 中的任何一个值。

情况2: 垂直滚动时,粘性约束元素高度小于等于 sticky 元素高度

当粘性约束元素滚出视口时,sticky 元素也会滚出视口。粘性约束元素比 sticky 元素还小,sticky 元素没有显示固定定位状态的机会。

情况3: 粘性约束元素和容器元素之间存在 overflow: hidden 的元素

必须要把 overflow: hidden 的元素移除。

以上这篇深入理解position sticky 粘性定位就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持芦苇派。

原创文章,作者:ECHO陈文,如若转载,请注明出处:https://www.luweipai.cn/html/1713430505/

  • 2