详解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绘制天猫logo实现代码
Nov 06 HTML / CSS
css3进行截取替代js的substring
Sep 02 HTML / CSS
什么是CSS3 HSLA色彩模式?HSLA模拟渐变色条
Apr 26 HTML / CSS
使用CSS3中的calc()属性来以算式表达尺寸数值
Jun 06 HTML / CSS
canvas实现有递增动画的环形进度条的实现方法
Jul 10 HTML / CSS
html5适合移动应用开发的12大特性
Mar 19 HTML / CSS
HTML5 新标签全部总汇(推荐)
Jun 13 HTML / CSS
HTML5+CSS3模仿优酷视频截图功能示例
Jan 05 HTML / CSS
详解HTML5 录音的踩坑之旅
Dec 26 HTML / CSS
CSS代码检查工具stylelint的使用方法详解
Mar 27 HTML / CSS
纯html+css实现打字效果
Aug 02 HTML / CSS
HTML中的表格元素介绍
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
PHP 网页过期时间的控制代码
2009/06/29 PHP
PHP 的ArrayAccess接口 像数组一样来访问你的PHP对象
2010/10/12 PHP
PHP实现一个简单url路由功能实例
2016/11/05 PHP
Centos 6.5系统下编译安装PHP 7.0.13的方法
2016/12/19 PHP
thinkphp分页集成实例
2017/07/24 PHP
PHP给源代码加密的几种方法汇总(推荐)
2018/02/06 PHP
javascript 自动转到命名锚记
2009/01/10 Javascript
JavaScript OOP类与继承
2009/11/15 Javascript
jquery的键盘事件修改代码
2011/02/24 Javascript
JS实现自适应高度表单文本框的方法
2015/02/25 Javascript
AngularJS基础 ng-mouseleave 指令详解
2016/08/02 Javascript
Vue-cli-webpack搭建斗鱼直播步骤详解
2017/11/17 Javascript
nodejs中密码加密处理操作详解
2018/03/20 NodeJs
使用vue-cli创建项目的图文教程(新手入门篇)
2018/05/02 Javascript
详解小程序循环require之坑
2019/03/08 Javascript
原生JS无缝滑动轮播图
2019/10/22 Javascript
JavaScript canvas实现雪花随机动态飘落
2020/02/08 Javascript
Vue+Element自定义纵向表格表头教程
2020/10/26 Javascript
[05:02][DOTA2]DOTA进化论 第一期
2013/09/27 DOTA
python连接mysql并提交mysql事务示例
2014/03/05 Python
Python迭代器与生成器基本用法分析
2018/07/26 Python
使用python实现快速搭建简易的FTP服务器
2018/09/12 Python
Python UnboundLocalError和NameError错误根源案例解析
2018/10/31 Python
Python多进程fork()函数详解
2019/02/22 Python
Python爬虫爬取博客实现可视化过程解析
2020/06/29 Python
YSL圣罗兰美妆英国官网:Yves Saint Laurent Beauty UK
2019/08/03 全球购物
卡拉威高尔夫官方网站:Callaway Golf
2020/09/16 全球购物
介绍一下Java的安全机制
2012/06/28 面试题
食堂采购员岗位职责
2014/03/17 职场文书
艾滋病宣传标语
2014/06/25 职场文书
防灾减灾宣传标语
2014/10/07 职场文书
党组织领导班子整改方案
2014/10/25 职场文书
小英雄雨来观后感
2015/06/09 职场文书
2015年社区反邪教工作总结
2015/10/14 职场文书
Spring Security使用单点登录的权限功能
2022/04/03 Java/Android
Windows Server 2012 R2服务器安装与配置的完整步骤
2022/07/15 Servers