• 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;
    }
  • 相关阅读:
    大数问题(三)(大数相除)
    直接插入排序的四种实现方法
    蟠桃记
    杭电oj find your present (2)
    CSS中的class与id区别及用法
    史上最全的css hack(ie6-9,firefox,chrome,opera,safari) (zz)
    CSS之CSS hack
    HTML语言的一些元素(五)
    HTML语言的一些元素(四)
    HTML语言的一些元素(三)
  • 原文地址:https://www.cnblogs.com/liuhao-web/p/8706672.html
Copyright © 2020-2023  润新知