在开发移动端app时,经常会碰到需要这样一种情况 —— 网站滚动到一定高度的时候,让一部分内容作为na vb ar,也就是置顶显示,我们一般会使用js监听scroll事件来实现,但是新增的css属性pos IT ion:sticky可以 简单 实现
我不是最后一个 知道 的:position: sticky
position的含义是指定位类型,取值类型可以有: stat ic、relative、absolute、fixed、inherit和sticky,这里sticky是CSS3新发布的一个属性。我今天重点要说的就是sticky属性
position:sticky用法
position:sticky 被称为粘性定位元素(stickily positioned element)是计算后位置属性为 sticky 的元素。 简单的理解就是:在目标区域以内,它的行为就像 position:relative;在滑动 过程中 ,某个元素 距离 其父元素的距离达到sticky粘性定位的要求时(比如top:100px);position:sticky这时的效果相当于fixed定位,固定到适当位置。 可以说是相对定位relative和固定定位fixed的结合 元素固定的相对偏移是相对于离它最近的具有滚动框的祖先元素,如果祖先元素都不可以滚动,那么是相对于viewport来计算元素的偏移量。 &nbs p;position:sticky 使用条件
1.父元素不能overflow:hidden 或者 overflow:auto属性。 2.必须指定top、bottom、left、right4个值之一,否则只会处于相对定位 3.父元素的高度不能低于sticky元素的高度 4、sticky元素仅在其父元素内 生效
例子
当鼠标下滑到一定高度时,触发position:sticky定位的要求,让[流行,新款,精选]固定为距离顶部44px的地方。
css代码
.tab-control{ position: sticky; top: 44px; }
ht ML 区域
<tab-control class="tab-control" :titles="['流行','新款','精选']"></tab-control>
在web开发中注意兼容性:
sticky目前仍是一个试验性的属性,并不是W3C推荐的标准。它之所以会出现,也是因为监听scroll事件来实现粘性布局使浏览器进入慢滚动的模式,这与浏览器想要通过 硬件 加速来 提升 滚动的体验是相悖的。具体情况可以看下图,基本上可以说这个属性使用的浏览器只有FireFox和iOS的Safari
总结
到此这篇关于CSS中的 position属性sticky详解的 文章 就介绍到这了,更多相关css position属性sticky内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
总结
以上是 为你收集整理的 CSS中的 position属性sticky详解 全部内容,希望文章能够帮你解决 CSS中的 position属性sticky详解 所遇到的问题。
如果觉得 网站内容还不错, 推荐好友。
查看更多关于CSS中的 position属性sticky详解的详细内容...