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;
    }
  • 相关阅读:
    不同浏览器对于js中for循环的判断
    png格式图片背景不透明问题解决
    qq登陆错误提示
    T职场人生系列之二十四:程序员如何增加收入
    if [ $# eq 0 ]该语句是什么含义?
    动态IP修改注册表降低PING值教程(XP系统)
    c# List列表数据转换成树形结构
    net core EF 链接mysql 数据库
    net core 部署到windows 服务
    IdentityServer4 密码模式认证
  • 原文地址:https://www.cnblogs.com/liuhao-web/p/8706672.html
Copyright © 2011-2022 走看看