CSS 实现头部、页脚滚动和固定

在一般的网站中都会有头部和页脚。

头部会一直固定在最上面位置。

页脚呢,当页面内容超出一屏时,页脚在内容最后,当不足一屏时,在页面最下面。

实现方式有很多。这里使用的是 position:sticky;

sticky

sticky 粘性定位。是css新增的一个position属性。

为什么说是粘性定位,从适用场景来看:一开始显示,滚动到一定位置需要显示的元素。

在没有达到设置的粘着位置时,和正常元素一样,达到粘着距离,就好一直保持这个位置。

使用注意事项:

  1、父元素不能有 overflow 属性

  2、left、top、right、bottom 必须要有一个

  3、仅在父元素内生效,父元素的高度必须大于 sticky 元素高度

  4、兼容加 -webkit 前缀

下面是最简单的 header 使用:

.header{
  position:sticky;
  top:0;    
}

实现

下面是实现,头部和页脚的滚动和固定。

HTML 部分:

  <div class="layout">
    <div class="header">
    </div>

    <div class="footer">
    </div>
  </div>

CSS 部分:

复制代码
.layout {
  width: 100%;
  min-height: 100%;    // 这是为了 footer 在内容不足时能在最下面
  // height: 100%;  // 设置遮盖属性,sticky 超过这个高度就会消失

  .header {
    position: sticky;
    top: 0;
    display: flex;
    width: 100%;
    height: 80px;
  }

  .footer {
    position: sticky;
    top: calc(100% - 80px);
    height: 80px;
  }
}
复制代码

 

posted @   漠里  阅读(1721)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 周边上新:园子的第一款马克杯温暖上架
· 分享 3 个 .NET 开源的文件压缩处理库,助力快速实现文件压缩解压功能!
· Ollama——大语言模型本地部署的极速利器
· DeepSeek如何颠覆传统软件测试?测试工程师会被淘汰吗?
· 使用C#创建一个MCP客户端
点击右上角即可分享
微信分享提示