内容不足以铺满屏幕高度时,footer居底显示,如何页面铺满了则在内容最下面,4种方法

本文介绍了四种方法实现当页面内容不足时footer保持在底部,内容足够时footer紧随内容下方。关键点包括设置最小高度、使用负margin和padding配合box-sizing: border-box。详细代码示例可在文中找到。
摘要由CSDN通过智能技术生成

这篇在浏览博客时看到的,转载了他的文章 https://blog.csdn.net/u012076852/article/details/53068082

同样话不多说,直接上代码

方法一:



html:
<div class="page">
    主要页面
</div>
<footer>底部</footer>


css:
html,body{
    height: 100%;
    margin: 0;
    padding: 0;
}
.page{
    box-sizing: border-box;/*为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制*/
    min-height: 100%;
    padding-bottom: 300px;
}
footer{
    height: 300px;
    margin-top: -300px;
    opacity: 0.5;
}

主要内容放在page内部,page最小高度为100%(注意这里html,body高度也要设为100%)。page有个padding-bottom大小为footer的高度(按需要调整),最重要的一点page的box-sizing:border-box,为元素指定的任何内边距和边框都将在已设定的宽度和高度内进行绘制,也就是说page的padding-bottom也会设定在min-height:100%内。而footer的margin-top为负的自身高度,把自己拉到page的padding-bottom空白块上,从而达到需求效果。
优点:简洁明了,没有冗余的div盒子;
缺点:box-sizing:border-box的兼容问题,ie7以下包括ie7不支持


方法二:

html:
<div class="page-container">
    <div class="page-main">
        主要页面 
    </div>
    <footer>底部<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值