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实现跳动的动画效果
Sep 12 HTML / CSS
CSS3实例分享--超炫checkbox复选框和radio单选框
Sep 01 HTML / CSS
CSS3实现的炫酷菜单代码分享
Mar 12 HTML / CSS
CSS3实现大小不一的粒子旋转加载动画
Apr 21 HTML / CSS
HTML5之SVG 2D入门5—颜色的表示及定义方式
Jan 30 HTML / CSS
用html5的canvas画布绘制贝塞尔曲线完整代码
Aug 14 HTML / CSS
HTML5添加鼠标悬浮音响效果不使用FLASH
Apr 23 HTML / CSS
Html5新特性用canvas标签画多条直线附效果截图
Jun 30 HTML / CSS
基于HTML5代码实现折叠菜单附源码下载
Nov 27 HTML / CSS
HTML5新增加的功能详解
Sep 05 HTML / CSS
Html5 滚动穿透的方法
May 13 HTML / CSS
CSS实现章节添加自增序号的方法
Jun 23 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
为IP查询添加GOOGLE地图功能的代码
2010/08/08 PHP
php去除二维数组的重复项方法
2015/11/03 PHP
PHP中模拟链表和链表的基本操作示例
2016/02/27 PHP
Yii-自定义删除确认弹框(zyd)jquery实现代码
2013/03/04 Javascript
下载文件个别浏览器文件名乱码解决办法
2013/03/19 Javascript
JS小功能(onmouseover实现选择月份)实例代码
2013/11/28 Javascript
jQuery实现动画效果的简单实例
2014/01/27 Javascript
Jquery Uploadify上传带进度条的简单实例
2014/02/12 Javascript
javascript实现判断鼠标的状态
2015/07/10 Javascript
基于JavaScript实现定时跳转到指定页面
2016/01/01 Javascript
微信公众平台开发教程(六)获取个性二维码的实例
2016/12/02 Javascript
AngularJS定时器的使用与移除操作方法【interval与timeout】
2016/12/14 Javascript
JS正则匹配中文的方法示例
2017/01/06 Javascript
微信小程序实战之自定义模态弹窗(8)
2017/04/18 Javascript
Angular入口组件(entry component)与声明式组件的区别详解
2018/04/09 Javascript
js实现移动端轮播图
2020/12/21 Javascript
Vue注册组件命名时不能用大写的原因浅析
2019/04/25 Javascript
Vue 幸运大转盘实现思路详解
2019/05/06 Javascript
关于vue项目中搜索节流的实现代码
2019/09/17 Javascript
vue-router 控制路由权限的实现
2020/09/24 Javascript
对于Python中线程问题的简单讲解
2015/04/03 Python
python抓取最新博客内容并生成Rss
2015/05/17 Python
利用Django-environ如何区分不同环境
2018/08/26 Python
python看某个模块的版本方法
2018/10/16 Python
python覆盖写入,追加写入的实例
2019/06/26 Python
python3获取当前目录的实现方法
2019/07/29 Python
通过python检测字符串的字母
2020/02/18 Python
Python 爬取淘宝商品信息栏目的实现
2021/02/06 Python
Saucony澳大利亚官网:美国跑鞋品牌,运动鞋中的劳斯莱斯
2018/05/05 全球购物
土木工程专业自荐信
2013/10/04 职场文书
经贸日语毕业生自荐信
2013/11/03 职场文书
业务员岗位职责
2015/02/03 职场文书
超市采购员岗位职责
2015/04/07 职场文书
刘胡兰观后感
2015/06/16 职场文书
《圆的周长》教学反思
2016/02/17 职场文书
2016年保险公众宣传日活动总结
2016/04/05 职场文书