为了账号安全,请及时绑定邮箱和手机立即绑定

sticky footer 的几种实现方法

标签:
Html5 CSS3

方法一:利用padding和margin

利用margin

DOM 结构

<div class="content">content</div>
<footer class="footer">sticky footer</footer>


CSS
html,body{
	height:100%;
}
.content{
	min-height:100%;
	margin-bottom:-100px;
}
.footer,.content:after{
	height:100px;  /* 防止动态添加html时造成footer被覆盖 */
}

利用padding,会多一层DOM结构

DOM
<div class="wrap">
	<main></main>
	<footer></footer>	
</div>

CSS
.wrap{
	box-sizing:border-box;
	min-height:100%;
	padding-bottom:100px;
}
main{
	min-height:100%;
}
footer{
	margin-bottom:-100px;
	height:100px;
}

方法二: 利用calc() 属性

.content{
	height: calc(100% - 100px);
}

方法三: flex

DOM 结构 同上
CSS
html{
	height:100%;
}
html body{
	min-height:100%;
	display:flex;
	flex-direction:column;
	
}
.content{
	flex:1; 
}
.footer{
	height:100px;
	flex:none;  /*flex 默认值为0 1 auto */
}

方法四:gird

缺点:兼容性不好

body{
	display:grid;
	grid-template-rows:80px auto 100px;
}

方法五: 绝对定位

DOM结构(随意)
<div class="content">
	i am content
</div>
<div class="footer"></div>

CSS
html{
	min-height:100%;
	position:relative;
}
body{
	margin-bottom:100px;
}
.footer{
	position:absolute;
	height:100px;
	width:100%;
	bottom:0;
}

方法六:table

兼容所有主流浏览器

DOM 结构
<div class="wrap">
	<header></header>
	<main></main>
	<footer></footer>
</div>
CSS
html,body,.wrap{
	height:100%;
}
.wrap{
	display:table;
}
header,footer,.main{
	display:block;  /*IE7 and under*/
	display:table-row;
}
header,footer{
	height:1
}

暂时整理这么多

点击查看更多内容
2人点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消