position:sticky和粘性定位的计算规则

129 阅读3分钟

position:sticky

单词sticky的中文意思是“粘性的”,是position:relativeposition:fixed的结合体, 当元素在屏幕内,表现为relative,就要滚出显示器屏幕的时候,表现为fixed

注意事项 sticky元素效果完全受制于父级元素们

  • 父级元素不能有任何overflow:visible以外的overflow设置,否则没有粘滞效果。因为改变了滚动容器(即使没有出现滚动条)
  • 父级元素设置和粘性定位元素等高的固定的height高度值,或者高度计算值和粘性定位元素高度一样,也没有粘滞效果
  • 同一个父容器中的sticky元素,如果定位值相等,则会重叠;如果属于不同父元素,且这些父元素正好紧密相连,则会鸠占鹊巢,挤开原来的元素,形成依次占位的效果
  • sticky定位,不仅可以设置top,基于滚动容器上边缘定位;还可以设置bottom,也就是相对底部粘滞。如果是水平滚动,也可以设置leftright值。

计算规则

粘性定位中有一个“流盒”(flow box)的概念,指的是粘性定位元素最近的可滚动元素(overflow属性值不是visible的元素)的尺寸盒子,如果没有可滚动元素,则表示浏览器视窗盒子。

粘性定位中还有一个名叫“粘性约束矩形”的概念,表示的是粘性定位元素的包含块在文档流中呈现的矩形区域和流盒的四个边缘在应用粘性定位元素的lefttoprightbottom属性的偏移计算值后的新矩形的交集。

滚动的时候,流盒不变,粘性定位元素的包含块跟着滚动 所以父级元素滚动时 粘性元素会跟着走

假设粘性定位元素只设置了top属性值,粘贴定位元素碰到粘性约束矩形的顶部的时候开始向下移动,直到它完全包含在粘贴约束矩形中。

其他特征

  • 如果我们的粘性定位元素的某个祖先元素的overflow属性值不是visible,那么页面滚动的时候就不会有粘性定位效果。为了避免当多个滚动互相嵌套的时候,粘性定位混乱。
  • 同一容器中多个粘贴定位元素独立偏移,因此可能重叠;位置上下靠在一起的不同容器中的粘贴定位元素则会鸠占鹊巢,挤开原来的元素,形成依次占位的效果。

当粘性定位元素都在一个容器的时候,大家都共用一个巨大的粘性约束矩形,因此,滚动的时候会一个一个往上重叠。但属于不同容器的时候,就会有多个不同的粘性约束矩形,这些粘性约束矩形正好一个一个排列得很整齐,于是视觉上达成一个巧合一般的约定,即上一个粘性定位元素被滚走,下一个粘性定位元素正好开始有粘性效果。

具体交互效果可搜索别的大神的文章看看