position的sticky与fixed 及固定上部分页面 使用举例

fixed(固定定位)

      生成绝对定位的元素,相对于浏览器窗口进行定位。元素的位置通过 "left", "top", "right" 以及 "bottom" 属性进行规定。可通过z-index进行层次分级。

sticky

  position属性中最有意思的就是sticky了,设置了sticky的元素,在屏幕范围(viewport)时该元素的位置并不受到定位影响(设置是top、left等属性无效),当该元素的位置将要移出偏移范围时,定位又会变成fixed,根据设置的left、top等属性成固定位置的效果。

  可以知道sticky属性有以下几个特点:

  • 该元素并不脱离文档流,仍然保留元素原本在文档流中的位置。
  • 当元素在容器中被滚动超过指定的偏移值时,元素在容器内固定在指定位置。亦即如果你设置了top: 50px,那么在sticky元素到达距离相对定位的元素顶部50px的位置时固定,不再向上移动。
  • 元素固定的相对偏移是相对于离它最近的具有滚动框的祖先元素,如果祖先元素都不可以滚动,那么是相对于viewport来计算元素的偏移量

 此属性,它之所以会出现,也是因为监听scroll事件来实现粘性布局使浏览器进入慢滚动的模式,这与浏览器想要通过硬件加速来提升滚动的体验是相悖的。

  具体情况可以看下图,基本上可以说这个属性使用的浏览器只有FireFox和iOS的Safari:

以上使用的浏览器是参考其他人2018 年调查结果,现在也可使用的浏览器Edge、Chrome

 简单的说,要让sticky属性生效的条件有以下两点:

  • 一个是元素自身在文档流中的位置
  • 另一个是该元素的父容器的边缘

  第一点上面已经讲过了,如果设置了top: 50px,那么元素在达到距离顶部50px时才会发生定位,否则并不会发生定位。

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

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

固定上部分页面使用举例:

<title>Sticky Header Example</title>
<style>
  body, html {
    height: 100%;
    margin: 0;
    padding: 0;
  }
  .header {
    position: sticky;
    top: 0;

    background-color: #f9f9f9;
    border-bottom: 1px solid #ddd;
    padding: 10px 0;
    text-align: center;
  }
  .content {
    height: 2000px; /* Just for demonstration */
    padding-top: 50px; /* Same as header height to prevent overlap */
  }
</style>
</head>
<body>
 
<div class="header">Header Content</div>
<div class="content">
  Your content goes here...
</div>
 
</body>
</html>

  • 21
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 如果你想要固定整个页面,但是不能使用`position: fixed`,你可以尝试使用`position: absolute`来达到同样的效果。 使用`position: absolute`的方法如下: 1. 给整个页面包裹一个容器,并给容器设置`position: absolute`和四周的边距。 2. 给整个页面设置一个固定的宽度和高度,并设置垂直居中和水平居中的样式。 3. 设置滚动条的样式,使得滚动条不可见。 下面是一个简单的例子: ```css .page { position: absolute; top: 50px; right: 50px; bottom: 50px; left: 50px; width: 800px; height: 600px; margin: auto; overflow: hidden; } ``` 这样就可以固定整个页面了。但是要注意,使用`position: absolute`会使元素脱离文档流,因此在布局时可能会有一些限制。 ### 回答2: 如果无法使用position: fixed固定整个页面,您可以尝试其他方法。 一种方法是使用JavaScript来实现页面固定效果。您可以通过以下步骤来实现: 1. 获取页面中的主要容器元素,例如body或者一个具有固定高度的div。 2. 监听滚动事件,当滚动事件被触发时,执行以下步骤: 3. 使用JavaScript的scrollTop属性来获取页面滚动的垂直距离。 4. 将滚动的垂直距离应用到主要容器元素的marginTop属性上,使其看起来固定。 以下是一个示例代码: ```javascript window.addEventListener('scroll', function() { var scrollDistance = window.pageYOffset || document.documentElement.scrollTop; var mainContainer = document.getElementById('main-container'); mainContainer.style.marginTop = scrollDistance + 'px'; }); ``` 在这个示例中,我们通过监听滚动事件并获取滚动的垂直距离,然后将该距离应用到页面的主要容器元素上,从而实现页面固定效果。 需要注意的是,这种方法可能需要一些调整,以确保页面布局不会因为固定效果而产生错位或重叠的情况。同时,这种方法也可能不适用于某些复杂的页面结构。 希望这个方法能够帮助到您! ### 回答3: 如果不能使用position: fixed固定整个页面,可以考虑使用其他方法来实现类似效果。 一种可能的解决方案是使用CSS的sticky属性。sticky属性让元素在滚动时保持位置,并在滚动到某个点后变为固定定位。这样可以模拟position: fixed的效果。 首先,在CSS中,将页面的根元素(通常是body或html)设置为相对定位,以便让其他元素相对于根元素进行定位。可以使用以下样式: html, body { position: relative; } 然后,将要固定的元素使用sticky属性。例如,如果要固定顶部导航栏,可以使用以下样式: .navbar { position: sticky; top: 0; } 其中,navbar是要固定的元素的类名,top属性指定元素相对于视口顶部的偏移量,0表示顶部对齐。 需要注意的是,sticky属性的兼容性并不完美。在一些旧版本的浏览器中可能不被支持。因此,在实际使用时,需要根据实际情况进行兼容性测试。 除了使用sticky属性外,还可以考虑使用JavaScript来实现固定页面的效果。通过监听滚动事件,根据滚动位置来动态添加或移除元素的固定定位样式。这样可以在更广泛的浏览器中实现类似的效果。但需要注意,使用JavaScript会增加页面的复杂性和加载时间,所以需要根据实际需求进行权衡和选择。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值