详解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中的注音对齐属性ruby-align用法指南
Jul 01 HTML / CSS
一款纯css3实现的颜色渐变按钮的代码教程
Nov 12 HTML / CSS
css3实现3D色子翻转特效
Dec 23 HTML / CSS
CSS3+js实现简单的时钟特效
Mar 18 HTML / CSS
HTML5的Geolocation地理位置定位API使用教程
May 12 HTML / CSS
html通过canvas转成base64的方法
Jul 18 HTML / CSS
前端canvas动画如何转成mp4视频的方法
Jun 17 HTML / CSS
html5 Canvas画图教程(3)—canvas出现1像素线条模糊不清的原因
Jan 09 HTML / CSS
解决Firefox下不支持outerHTML问题代码分享
Jun 04 HTML / CSS
一文彻底解决HTML5页面中长按保存图片功能
Jun 10 HTML / CSS
详解HTML5 Canvas标签及基本使用
Jan 10 HTML / CSS
HTML+CSS制作心跳特效的实现
May 26 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
雄兵连:天使彦天使彦为爱折翼,彦和炙心同时念动的誓言!
2020/03/02 国漫
destoon调用自定义模板及样式的公告栏
2014/06/21 PHP
PHP通过API获取手机号码归属地
2015/05/28 PHP
php字符集转换
2017/01/23 PHP
php制作基于xml的RSS订阅源功能示例
2017/02/08 PHP
CakePHP框架Model关联对象用法分析
2017/08/04 PHP
JQuery团队打造的javascript单元测试工具QUnit介绍
2010/02/26 Javascript
jQuery实现延迟跳转的方法
2015/06/05 Javascript
以jQuery中$.Deferred对象为例讲解promise对象是如何处理异步问题
2015/11/13 Javascript
使用HTML5+Boostrap打造简单的音乐播放器
2016/08/05 Javascript
jquery实现表单获取短信验证码代码
2017/03/13 Javascript
nodejs个人博客开发第一步 准备工作
2017/04/12 NodeJs
详解node+express+ejs+bootstrap构建项目
2017/09/27 Javascript
微信小程序上传图片到服务器实例代码
2017/11/07 Javascript
解决JSON.stringify()自动将中文转译成unicode的问题
2018/01/05 Javascript
vue2.0之多页面的开发的示例
2018/01/30 Javascript
vuex实现的简单购物车功能示例
2019/02/13 Javascript
[00:36]DOTA2上海特级锦标赛 Archon战队宣传片
2016/03/04 DOTA
python进阶教程之函数对象(函数也是对象)
2014/08/30 Python
Python 多进程和数据传递的理解
2017/10/09 Python
Python多线程处理实例详解【单进程/多进程】
2019/01/30 Python
python制作填词游戏步骤详解
2019/05/05 Python
python网络编程 使用UDP、TCP协议收发信息详解
2019/08/29 Python
Python实现多线程下载脚本的示例代码
2020/04/03 Python
python文件操作seek()偏移量,读取指正到指定位置操作
2020/07/05 Python
Python logging日志库空间不足问题解决
2020/09/14 Python
Python模拟登录requests.Session应用详解
2020/11/17 Python
英国百年闻名的优质健康产品连锁店:Holland & Barrett
2019/12/19 全球购物
经典c++面试题二
2015/08/14 面试题
运动会入场词100字
2014/02/06 职场文书
会计电算化应届生自荐信
2014/02/25 职场文书
数学教师个人总结
2015/02/06 职场文书
后勤工作个人总结
2015/02/28 职场文书
金陵十三钗观后感
2015/06/04 职场文书
python异常中else的实例用法
2021/06/15 Python
Java完整实现记事本代码
2022/06/16 Java/Android