zoukankan      html  css  js  c++  java
  • CSS 五种方式实现 Footer 置底

    CSS 五种方式实现 Footer 置底

     

    页脚置底(Sticky footer) 就是让网页的footer部分始终在浏览器窗口的底部。

    当网页内容足够长以至超出浏览器可视高度时,页脚会随着内容被推到网页底部; 但如果网页内容不够长,置底的页脚就会保持在浏览器窗口底部。

    方法一:将内容部分的margin-bottom设为负数

    <div class="wrapper">
        <!-- content -->
        <div class="push"></div>
    </div>
    <div class="footer">footer</div>
    html, body {
      margin: 0;
      padding: 0;
      height: 100%;
    }
    .wrapper {
      min-height: 100%;  
      margin-bottom: -50px; /* 等于footer的高度 */
    }
    .footer, .push {
      height: 50px;
    }
    1. 这个方法需要容器里有额外的占位元素(div.push)。

    2. div.wrappermargin-bottom需要和div.footer-height值一样,注意是负height

    方法二:将页脚的margin-top设为负数

    • 给内容外增加父元素,并让内容部分的padding-bottom与页脚的height相等。
    <div class="content">
      <div class="content-inside">
        <!-- content -->
      </div>
    </div>
    <div class="footer">footer</div>
    html, body {
      margin: 0;
      padding: 0;
      height: 100%;
    }
    .content {
      min-height: 100%;
    }
    .content-inside {
      padding: 20px;
      padding-bottom: 50px;
    }
    .footer {
      height: 50px;
      margin-top: -50px;
    }

    方法三:使用calc()设置内容高度

    <div class="content">
      <!-- content -->
    </div>
    <div class="footer">footer</div>
    .content {
      min-height: calc(100vh - 70px);
    }
    .footer {
      height: 50px;
    }
    • 这里假设div.contentdiv.footer之间有20px的间距,所以70px=50px+20px

    方法四:使用flexbox弹性盒布局

    以上三种方法的footer高度都是固定的,如果footer的内容太多则可能会破坏布局。

    <div class="content">
      <!-- content -->
    </div>
    <div class="footer">footer</div>
    html {
      height: 100%;
    }
    body {
      min-height: 100%;
      display: flex;
      flex-direction: column;
    }
    .content {
      flex: 1;
    }

    方法五:使用Grid网格布局

    <div class="content">
      <!-- content -->
    </div>
    <div class="footer">footer</div>
    html {
      height: 100%;
    }
    body {
      min-height: 100%;
      display: grid;
      grid-template-rows: 1fr auto;
    }
    .footer {
      grid-row-start: 2;
      grid-row-end: 3;
    }
  • 相关阅读:
    模板学习系列(一)tuple
    apue读书笔记第十章
    在亚马逊上关于设计模式的一个评论
    编程珠玑笔记第12章习题
    编程珠玑第14章
    C#,.Net经典面试题目及答案
    sql where 1=1和 0=1 的作用(junyuz)
    快速排序算法
    一道面试题(C#实现了超大整数的加减乘法运算)
    数据结构实验之链表一:顺序建立链表
  • 原文地址:https://www.cnblogs.com/liuhao-web/p/8706672.html
Copyright © 2011-2022 走看看