详解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教程(6):创建网站多列
Apr 02 HTML / CSS
CSS3弹性盒模型flex box快速入门心得(必看篇)
May 24 HTML / CSS
CSS3 @media的基本用法总结
Sep 10 HTML / CSS
HTML5 Plus 实现手机APP拍照或相册选择图片上传功能
Jul 13 HTML / CSS
使用HTML5原生对话框元素并轻松创建模态框组件
Mar 06 HTML / CSS
Canvas 文本转粒子效果的实现代码
Feb 14 HTML / CSS
HTML5之HTML元素扩展(下)—增强的Form表单元素值得关注
Jan 31 HTML / CSS
html5实现完美兼容各大浏览器的播放器
Dec 26 HTML / CSS
实例讲解使用SVG制作loading加载动画的方法
Apr 05 HTML / CSS
h5页面唤起app如果没安装就跳转下载(iOS和Android)
Jun 03 HTML / CSS
html+css实现文字折叠特效实例
Jun 02 HTML / CSS
html+css实现滚动到元素位置显示加载动画效果
Aug 02 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实现在服务器上创建目录的方法
2015/03/16 PHP
使用php+swoole对client数据实时更新(一)
2016/01/07 PHP
PHP会话操作之cookie用法分析
2016/09/28 PHP
PHP随机获取未被微信屏蔽的域名(微信域名检测)
2017/03/19 PHP
PHP后端银联支付及退款实例代码
2017/06/23 PHP
laravel框架中间件简单使用方法示例
2020/01/25 PHP
jQuery使用手册之三 CSS操作
2007/03/24 Javascript
JS防止用户多次提交的简单代码
2013/08/01 Javascript
JavaScript基本数据类型及值类型和引用类型
2015/08/25 Javascript
jQuery插件编写步骤详解
2016/06/03 Javascript
JavaScript的instanceof运算符学习教程
2016/06/08 Javascript
基于iscroll.js实现下拉刷新和上拉加载效果
2016/11/28 Javascript
基于JavaScript实现随机颜色输入框
2016/12/10 Javascript
AngularJS实现表单验证功能
2017/01/09 Javascript
微信小程序 页面跳转和数据传递实例详解
2017/01/19 Javascript
React-Router如何进行页面权限管理的方法
2017/12/06 Javascript
Angular中管道操作符(|)的使用方法
2017/12/15 Javascript
JS中使用textPath实现线条上的文字
2017/12/25 Javascript
Vue路由history模式解决404问题的几种方法
2018/09/29 Javascript
详解vue或uni-app的跨域问题解决方案
2020/02/21 Javascript
vue实现购物车的小练习
2020/12/21 Vue.js
Python随机生成数据后插入到PostgreSQL
2016/07/28 Python
利用Python批量生成任意尺寸的图片
2016/08/29 Python
Python 模拟购物车的实例讲解
2017/09/11 Python
Python对象中__del__方法起作用的条件详解
2018/11/01 Python
使用PyQtGraph绘制精美的股票行情K线图的示例代码
2019/03/14 Python
pytorch程序异常后删除占用的显存操作
2020/01/13 Python
Python加载数据的5种不同方式(收藏)
2020/11/13 Python
时尚、社区、科技:SEVENSTORE
2019/04/26 全球购物
羽毛球比赛策划方案
2014/06/13 职场文书
个人委托书范本
2014/09/13 职场文书
缓刑期间思想汇报范文
2014/10/10 职场文书
小学元宵节活动总结
2015/02/06 职场文书
python opencv旋转图片的使用方法
2021/06/04 Python
项目中Nginx多级代理是如何获取客户端的真实IP地址
2022/05/30 Servers
Python 读取千万级数据自动写入 MySQL 数据库
2022/06/28 Python