详解Sticky Footer 绝对底部的两种套路


Posted in HTML / CSS onNovember 03, 2017

最近面了好几个前端,工作经验有高有低,居然都不知道绝对底部是什么,也没有人能说出一种实现方式,让我不禁感慨前端领域的良莠不齐

绝对底部,或者说 Sticky Footer,是一种古老且经典的页面效果:

当页面内容超出屏幕,页脚模块会像正常页面一样,被推到内容下方,需要拖动滚动条才能看到

而当页面内容小于屏幕高度,页脚模块会固定在屏幕底部,就像是底边距为零的固定定位

详解Sticky Footer 绝对底部的两种套路

一、经典套路

这种套路的思路是,给内容区域设置 min-height: 100%,将 footer 推到屏幕下方

然后给 footer 添加 margin-top,其值为 footer 高度的负值,就能让 footer 回到屏幕底部

HTML:

<div class="wrap">
  <div class="content">
    <p>填充内容</p>
  </div>
</div>
<div class="footer">
  <p>这是页脚</p>
</div>

CSS:

html,body {
  height: 100%;
}
    
body > .wrap {
  min-height: 100%;
}
    
.content {
  /* padding-bottom 等于 footer 的高度 */
  padding-bottom: 60px;
}
    
.footer {
  width: 100%;
  height: 60px;
  /* margin-top 为 footer 高度的负值 */
  margin-top: -60px;
}

需要注意的就是内容区域 content 的 padding、footer 的 height 和 margin, 必须保持一致

这种写法的兼容性非常好,实测 IE7 也能正常展示

但是如果页面的主体布局有其他兼容性问题,Sticky Footer 就需要做一些相应的修改

二、Flexbox

不得不说,CSS3 带来了前端的一次变革,其中 Flexbox 更是带来了网页布局的一次变革

虽然兼容性限制了 Flexbox 在国内的推广,但不可否认的是,Flexbox 是前端布局的一大趋势

HTML:

<div class="content">
  <p>填充内容</p>
  <hr />
</div>
<div class="footer">
  <p>这是页脚@WiseWrong</p>
</div>

CSS:

html, body {
  display: flex;
  height: 100%;
  flex-direction: column;
}

body > .content {
  flex: 1;
}

和经典套路相比,首先是 HTML 部分,内容区域 content 不再需要 wrap 容器

然后 CSS 部分减肥成功,仅仅使用四行代码,就解决了曾经困扰了一代人的难题

而且使用 Flexbox,就不需要限定 footer 的高度,让页面布局更加灵活

当然缺点也是显而易见的,只有 IE10 及以上的浏览器才支持 flex 布局

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3新属性transition-property transform box-shadow实例学习
Jun 06 HTML / CSS
CSS图片翻转动画技术详解(IE也实现了)
Apr 03 HTML / CSS
使用CSS3制作饼状旋转载入效果的实例
Jun 23 HTML / CSS
CSS3 不定高宽垂直水平居中的几种方式
Mar 26 HTML / CSS
解决CSS3 transition-delay 属性默认值0不带单位失效的问题
Oct 29 HTML / CSS
html5 Canvas画图教程(5)—canvas里画曲线之arc方法
Jan 09 HTML / CSS
使用 HTML5 Canvas 制作水波纹效果点击图片就会触发
Sep 15 HTML / CSS
使用phonegap克隆和删除联系人的实现方法
Mar 31 HTML / CSS
HTML5单页面手势滑屏切换原理分析
Jul 10 HTML / CSS
html5小程序飞入购物车(抛物线绘制运动轨迹点)
Oct 19 HTML / CSS
详解如何解决H5开发使用wx.hideMenuItems无效果不生效
Jan 20 HTML / CSS
clear 万能清除浮动(clearfix:after)
May 21 HTML / CSS
CSS3 mask 遮罩的具体使用方法
Nov 03 #HTML / CSS
用CSS3实现无限循环的无缝滚动的示例代码
Nov 01 #HTML / CSS
用纯CSS3实现网页中常见的小箭头
Oct 16 #HTML / CSS
CSS3的颜色渐变效果的示例代码
Sep 29 #HTML / CSS
通过一张图教会你CSS3倒影的实现
Sep 26 #HTML / CSS
利用 CSS3 实现的无缝轮播功能代码
Sep 25 #HTML / CSS
CSS3中伪元素::before和::after的用法示例
Sep 18 #HTML / CSS
You might like
输出控制类
2006/10/09 PHP
PHP的FTP学习(一)
2006/10/09 PHP
PHP判断是否连接上网络的方法
2015/07/01 PHP
PHP使用反射机制实现查找类和方法的所在位置
2016/04/22 PHP
Laravel5.4框架中视图共享数据的方法详解
2019/09/05 PHP
laravel请求参数校验方法
2019/10/10 PHP
YUI的Tab切换实现代码
2010/04/11 Javascript
让ie6也支持websocket采用flash封装实现
2013/02/18 Javascript
基于NodeJS的前后端分离的思考与实践(二)模版探索
2014/09/26 NodeJs
node.js集成百度UE编辑器
2015/02/05 Javascript
简单纯js实现点击切换TAB标签实例
2015/08/23 Javascript
jQuery实现内容定时切换效果完整实例
2016/04/06 Javascript
jQuery阻止移动端遮罩层后页面滚动
2017/03/15 Javascript
Vue2.0实现购物车功能
2017/06/05 Javascript
vue-cli 自定义指令directive 添加验证滑块示例
2017/10/19 Javascript
谈谈vue中mixin的一点理解
2017/12/12 Javascript
Angular处理未可知异常错误的方法详解
2021/01/17 Javascript
CentOS 7 安装python3.7.1的方法及注意事项
2018/11/01 Python
PyQtGraph在pyqt中的应用及安装过程
2019/08/04 Python
详解Python利用random生成一个列表内的随机数
2019/08/21 Python
解决jupyter运行pyqt代码内核重启的问题
2020/04/16 Python
Python3 pywin32模块安装的详细步骤
2020/05/26 Python
Pytorch框架实现mnist手写库识别(与tensorflow对比)
2020/07/20 Python
出门问问全球官方商城:Tichome音箱和TicWatch智能手表
2017/12/02 全球购物
捷克街头、运动和滑板一站式商店:BoardStar.cz
2019/10/06 全球购物
什么是serialVersionUID
2016/03/04 面试题
幼儿园英语教学反思
2014/01/30 职场文书
酒店秘书求职信范文
2014/02/17 职场文书
小学生元旦感言
2014/02/26 职场文书
奥巴马胜选演讲稿
2014/05/15 职场文书
2015年团支部工作总结
2015/04/03 职场文书
让子弹飞观后感
2015/06/11 职场文书
2016大学生党校学习心得体会
2016/01/06 职场文书
浅谈MySQL next-key lock 加锁范围
2021/06/07 MySQL
Python MNIST手写体识别详解与试练
2021/11/07 Python
Pygame Rect区域位置的使用(图文)
2021/11/17 Python