css3 position:sticky粘性定位

  • 该元素并不脱离文档流,仍然保留元素原本在文档流中的位置。
  • 当元素在容器中被滚动超过指定的偏移值时,元素在容器内固定在指定位置。亦即如果你设置了top: 54px,那么在sticky元素到达距离相对定位的元素顶部50px的位置时固定,不再向上移动。
  • 元素固定的相对偏移是相对于离它最近的具有滚动框的祖先元素,如果祖先元素都不可以滚动,那么是相对于viewport来计算元素的偏移量
  • sticky属性生效的条件有以下两点:
  • 一个是元素自身在文档流中的位置
  • 另一个是该元素的父容器的边缘
  • 第一点如果设置了top: 54px,那么元素在达到距离顶部50px时才会发生定位,否则并不会发生定位。

      第二点则需要考虑父容器的高度情况:sticky元素在到达父容器的底部时,则不会再发生定位,如果父容器高度并没有比sticky元素高,那么sticky元素一开始就达到了底部,并不会有定位的效果。

      此外还有一点就是父元素的overflow属性,如果父元素的overflow属性并不是默认的visible属性,那么sticky元素则相对于该父元素定位。也就是如果要定位在顶部的话,此时这个效果就无效了

  • .filter_wrap {
      background: #fff;
      position: sticky;
      top: 54px;
      z-index: 10;
    }

     

  •  

你可能感兴趣的:(css3)