css如何把元素固定在容器底部的四种方式


Posted in HTML / CSS onJune 16, 2022

前几天被人问,「如何把元素固定在容器底部」。(本来想直接把 demo 地址给他,结果没找到,那么今天我们来补一下)

Demo 地址

css如何把元素固定在容器底部的四种方式

想法&思路

如果是页面底部,我们可以直接 position: fixed;bottom: 0; 基于浏览器定位直接实现。

但是他要的效果是基于父级容器,那么我们必须要使用其他手段来定位了

  • relative 来限制 absolute,然后 bottom: 0,但是在内容过长的时候会导致显示异常。所以我们需要做内部滚动。
  • 如果做内部滚动,那么我们只要可以撑开盒子即可。不需要绝对定位了

使用 flex 实现

  • 父级使用 flex 布局,column 垂直排列。
  • 父级定高(height、maxHeight),.content 子级 flex:auto; 自动撑开。 或者 .content 做高度限制。
  • footer 可以使用 absolute 加 padding 。或者完全依赖文档流布局都可以

    .demo1{
          position: relative;
          padding-bottom: 40px;
          display: inline-flex;
          flex-direction: column;
      }
      .demo1 .footer{
          position: absolute;
          bottom: 0;
          left: 0;right: 0;
          margin: 0;
      }
      .demo1 .content{
          overflow: auto;
      }

calc 实现

如果不使用 flex ,那么我们可以用 calc 来减去 header 和 footer 空间。

<style>
    .demo3{
        position: relative;
    }
    .demo3 .content{
        overflow: auto;
        max-height: calc(100% - 40px);
    }
</style>

absolute 实现

如果 calc 兼容性不太好,那么还可以使用 absolute 将所有元素都脱离文档流。

<style>
    .demo4{
        position: relative;
    }
    .demo4 .header,.demo4 .footer{
        position: absolute;
        margin: 0;
        top:0;left:0 ;right:0;
    }
    .demo4 .footer{
        top: auto;
        bottom: 0;
    }
    .demo4 .content{
        overflow: auto;
        height: 100%;
        padding-top: 30px;
        padding-bottom: 30px;
        margin: 0;
        box-sizing: border-box;
    }
</style>

到此这篇关于css如何把元素固定在容器底部的四种方式的文章就介绍到这了,更多相关css元素固定底部内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

 
HTML / CSS 相关文章推荐
详解纯CSS3制作的20种loading动效
Jul 05 HTML / CSS
CSS3五个技巧给你的网站带来出色的效果
Apr 02 HTML / CSS
css3实现背景颜色渐变让图片不再是唯一的实现方式
Dec 18 HTML / CSS
CSS3区域模块region相关编写示例
Aug 28 HTML / CSS
解决CSS3 transition-delay 属性默认值0不带单位失效的问题
Oct 29 HTML / CSS
html5之Canvas路径绘图、坐标变换应用实例
Dec 26 HTML / CSS
分享29个基于Bootstrap的HTML5响应式网页设计模板
Nov 19 HTML / CSS
HTML最新标准HTML5总结(必看)
Jun 13 HTML / CSS
使用phonegap创建联系人的实现方法
Mar 30 HTML / CSS
HTML5离线应用与客户端存储的实现
May 03 HTML / CSS
css3中2D转换之有趣的transform形变效果
Feb 24 HTML / CSS
css如何把元素固定在容器底部的四种方式
Jun 16 HTML / CSS
css中有哪些方式可以隐藏页面元素及区别
Jun 16 #HTML / CSS
CSS控制继承中的height能变为可继承吗
Jun 10 #HTML / CSS
css样式important规则的正确使用方式
Jun 10 #HTML / CSS
分享几个实用的CSS代码块
Jun 10 #HTML / CSS
html中两种获取标签内的值的方法
Jun 10 #HTML / CSS
html5+实现plus.io进行拍照和图片等获取
Jun 01 #HTML / CSS
基于CSS制作创意端午节专属加载特效
You might like
如何分别全角和半角以避免乱码
2006/10/09 PHP
discuz 首页四格:最新话题+最新回复+热门话题+精华文章插件
2007/08/19 PHP
PHP的substr_replace将指定两位置之间的字符替换为*号
2011/05/04 PHP
php编程实现获取excel文档内容的代码实例
2011/06/28 PHP
Apache中php.ini的设置方法
2013/02/28 PHP
PHP生成制作验证码的简单实例
2016/06/12 PHP
TNC vs BOOM BO3 第一场2.13
2021/03/10 DOTA
Extjs中常用表单介绍与应用
2010/06/07 Javascript
基于jquery的表头固定的若干方法
2011/01/27 Javascript
JavaScript高级程序设计(第3版)学习笔记11 内建js对象
2012/10/11 Javascript
jQuery动画animate方法使用介绍
2013/05/06 Javascript
浅析JavaScript访问对象属性和方法及区别
2015/11/16 Javascript
浅谈js数组和splice的用法
2016/12/04 Javascript
概述jQuery中的ajax方法
2016/12/16 Javascript
JavaScript中in和hasOwnProperty区别详解
2017/08/04 Javascript
基于axios封装fetch方法及调用实例
2018/02/05 Javascript
jQuery实现table表格信息的展开和缩小功能示例
2018/07/21 jQuery
node 解析图片二维码的内容代码实例
2019/09/11 Javascript
vue实现表格过滤功能
2019/09/27 Javascript
[42:25]EG vs Spirit Supermajor 败者组 BO3 第二场 6.4
2018/06/05 DOTA
python使用心得之获得github代码库列表
2014/06/25 Python
Python类定义和类继承详解
2015/05/08 Python
python安装twisted的问题解析
2018/08/21 Python
padas 生成excel 增加sheet表的实例
2018/12/11 Python
在Python文件中指定Python解释器的方法
2019/02/18 Python
浅谈python的深浅拷贝以及fromkeys的用法
2019/03/08 Python
pyqt5实现登录界面的模板
2020/05/30 Python
Python使用crontab模块设置和清除定时任务操作详解
2019/04/09 Python
python socket通信编程实现文件上传代码实例
2019/12/14 Python
keras中模型训练class_weight,sample_weight区别说明
2020/05/23 Python
Pytorch mask-rcnn 实现细节分享
2020/06/24 Python
爬虫代理的cookie如何生成运行
2020/09/22 Python
优秀广告词大全
2014/03/19 职场文书
干部鉴定材料
2014/05/18 职场文书
学校运动会感想
2015/08/10 职场文书
vue3引入highlight.js进行代码高亮的方法实例
2022/04/08 Vue.js