学习一下sticky-footer

什么是sticky-footer?

当页面长度不够长的时候,页脚粘贴在视窗底部:如果页面足够长时页脚会被内容向下推送。

实现方式:

1.负margin布局方式

    给内容div加一个父div,设置父div最小高度100%,内容div的padding-bottom为footer高度,给footer预留位置
    footer设置margin-top为负的footer高度,position为relative
    这样当页面内容少时,由于content的父div有最小高度100%,且footer有负margin-top,所以刚好处于页面底部;
    页面内容较多时,footer区块随着content自动撑开,且正好处于content的padding-bottom位置
    注意:content元素的padding-bottom、footer元素的高度以及footer元素的margin-top值必须要保持一致。
    这种负margin的布局方式,是兼容性最佳的布局方案,各大浏览器均可完美兼容,适合各种场景,
    但使用这种方式的前提是必须要知道footer元素的高度,且结构相对较复杂。 
    为了保证兼容性,需要在wrapper上添加clearfix类.

2.flex布局方式

    内容和footer的父div设置display:flex, flex-direction: column;这样content和footer就会垂直排列,
    再给content设置flex:1;footer设置flex:0,这样footer只会占据固有高度
    而内容少时,存在剩余空间,content会自动放大,占据除footer外的剩余空间
    当内容多时,没有多余空间,正常显示
    这样的布局简单使用,比较推荐。

3.为内容区域添加最小的高度

    这种方法需要精确知道content和footer的父div,即视窗的高度,设置content的最小高度为视窗高度减去footer高度
    这样内容少时,content为最小高度,footer在视窗底部
    内容多时,content变高,footer随content滚动
    这个方式和第一种差不多,不过这种方法需要需要精确知道各个div的高度,不方便 

html文件:
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>sticky-footer</title>
    <link rel="stylesheet/less" href="sticky-footer.less">
    <script src='./js-util/less.min.js'></script>
</head>
<body>
<div class="main">
    <div class="box box1">
        <div class="content-wrapper clearfix">
            <div class="content">
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
            </div>
        </div>
        <div class="footer">
            我是footer
        </div>
    </div>
    <div class="box box1">
        <div class="content-wrapper clearfix">
            <div class="content">
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
                负margin布局方式<br>
            </div>
        </div>
        <div class="footer">
            我是footer
        </div>
    </div>
    <div class="box box2">
        <div class="content">
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
        </div>
        <div class="footer">
            我是footer
        </div>
    </div>
    <div class="box box2">
        <div class="content">
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
            flex布局方式<br>
        </div>
        <div class="footer">
            我是footer
        </div>
    </div>
    <div class="box box3">
        <div class="content">
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
        </div>
        <div class="footer">
            我是footer
        </div>
    </div>
    <div class="box box3">
        <div class="content">
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
            第三种方式 <br>
        </div>
        <div class="footer">
            我是footer
        </div>
    </div>
</div>
</body>
</html>

  less文件:

.main {
    height: 800px;
    border: 1px solid #ccc;
    .box {
        float: left;
        width: 250px;
        height: 400px;
        background: #ddd;
        overflow: auto;
        text-align: center;
        padding: 10px;
        .footer {
            height: 100px;
            line-height: 100px;
            background: green;
        }
        &.box1 {
            background: pink;
            .content-wrapper {
                min-height: 100%;
                .content {
                    padding-bottom: 100px;
                }
                .clearfix {
                    display: inline-block;
                }
                .clearfix::after {
                    display: block;
                    content: ".";
                    height: 0;
                    clear: both;
                    visibility: hidden;
                }
            }
            .footer {
                position: relative;
                margin-top: -100px;
            }
        }
        &.box2 {
            background: goldenrod;
            display: flex;
            flex-direction: column;
            .content {
                flex: 1;
            }
            .footer {
                flex: 0;
            }
        }
        &.box3 {
            .content{
                min-height: 300px;;
                box-sizing:border-box;
           }    
        }
    }
}

  实现效果:

猜你喜欢

转载自www.cnblogs.com/yan89/p/9064021.html
今日推荐