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;
    }
  • 相关阅读:
    EF单实对应多表
    阻止保存要求重新创建表的更改
    Jenkins 修改主目录正解 workspace
    JNLP文件具体说明编辑
    Jenkins新建节点,启动方式没有“通过Java Web启动代理”选项怎么办?
    Entity Framework:“无法加载指定的元数据资源
    Java环境路径配置--转载
    趣谈StateServer在Web Garden,Web Farm下的使用
    【译文】漫谈ASP.NET中的Session
    好记心不如烂笔头之JQuery学习,第四章
  • 原文地址:https://www.cnblogs.com/liuhao-web/p/8706672.html
Copyright © 2011-2022 走看看