详解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实现的简单的鼠标悬停按钮
Nov 04 HTML / CSS
css3 实现元素弧线运动的示例代码
Apr 24 HTML / CSS
html Table 表头固定的实现
Jan 22 HTML / CSS
HTML5注册表单的自动聚焦与占位文本示例代码
Jul 19 HTML / CSS
HTML5 DeviceOrientation实现手机网站摇一摇功能代码实例
Apr 24 HTML / CSS
【HTML5】Canvas绘制简单图片教程
May 13 HTML / CSS
详解H5 活动页之移动端 REM 布局适配方法
Dec 07 HTML / CSS
详解px单位html5响应式方案
Mar 08 HTML / CSS
AmazeUI 缩略图的实现示例
Aug 18 HTML / CSS
浅析HTML5 meta viewport参数
Oct 28 HTML / CSS
使用HTML和CSS实现的标签云效果(附demo)
Feb 03 HTML / CSS
CSS中实现动画效果-附案例
Feb 28 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
改变Apache端口等配置修改方法
2008/06/05 PHP
PHP网站备份程序代码分享
2011/06/10 PHP
php比较两个绝对时间的大小
2014/01/31 PHP
thinkPHP自动验证、自动添加及表单错误问题分析
2016/10/17 PHP
PHP 实现浏览记录并按日期分组
2017/05/11 PHP
javascript:以前写的xmlhttp池,代码
2008/05/18 Javascript
Javascript在IE或Firefox下获取鼠标位置的代码
2009/12/18 Javascript
autoIMG 基于jquery的图片自适应插件代码
2011/03/12 Javascript
精心挑选的12款优秀的基于jQuery的手风琴效果插件和教程
2012/08/22 Javascript
javascript显示用户停留时间的简单实例
2013/08/05 Javascript
jquery中ready()函数执行的时机和window的load事件比较
2015/06/22 Javascript
JS实现超精简的链接列表在固定区域内滚动效果代码
2015/11/04 Javascript
JS实现的仿淘宝交易倒计时效果
2015/11/27 Javascript
老生常谈原生JS执行环境与作用域
2016/11/22 Javascript
js实现数组去重方法及效率?Ρ? target=
2017/02/14 Javascript
springMVC + easyui + $.ajaxFileUpload实现文件上传注意事项
2017/04/23 Javascript
Vue.js 2.0学习教程之从基础到组件详解
2017/04/24 Javascript
基于require.js的使用(实例讲解)
2017/09/07 Javascript
详解如何webpack使用DllPlugin
2018/09/30 Javascript
inquirer.js一个用户与命令行交互的工具详解
2019/05/18 Javascript
JavaScript this关键字指向常用情况解析
2020/09/02 Javascript
[05:04]DOTA2上海特级锦标赛主赛事第二日TOP10
2016/03/04 DOTA
[05:53]敌法师的金色冠名ID"BurNIng",是传说,是荣耀
2020/07/11 DOTA
Python开发编码规范
2006/09/08 Python
Python使用Redis实现作业调度系统(超简单)
2016/03/22 Python
python版本坑:md5例子(python2与python3中md5区别)
2017/06/20 Python
Python正则表达式知识汇总
2017/09/22 Python
在vscode中配置python环境过程解析
2019/09/28 Python
python自动化测试之异常及日志操作实例分析
2019/11/09 Python
《地震中的父与子》教学反思
2014/04/10 职场文书
慈善募捐倡议书
2015/04/27 职场文书
干货:企业内部人才推荐奖励方案!
2019/07/09 职场文书
2019年“我为祖国点赞”演讲稿(3篇)
2019/09/26 职场文书
JavaScript 对象创建的3种方法
2021/11/17 Javascript
Redis+Lua脚本实现计数器接口防刷功能(升级版)
2022/02/12 Redis
Win11 Build 25179预览版发布(附更新内容+ISO官方镜像下载)
2022/08/14 数码科技