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 please 跨浏览器的CSS3产生器
Mar 14 HTML / CSS
纯CSS3实现给头像加个光芒四射且旋转的背景动画效果
May 07 HTML / CSS
css3边框_动力节点Java学院整理
Jul 11 HTML / CSS
websocket+sockjs+stompjs详解及实例代码
Nov 30 HTML / CSS
分享一个页面平滑滚动小技巧(推荐)
Oct 23 HTML / CSS
浅谈HTML5 &amp; CSS3的新交互特性
Jul 19 HTML / CSS
HTML5高仿微信聊天、微信聊天表情|对话框|编辑器功能
Apr 23 HTML / CSS
canvas如何实现多张图片编辑的图片编辑器
Mar 10 HTML / CSS
Amaze UI 文件选择域的示例代码
Aug 26 HTML / CSS
详解HTML5布局和HTML5标签
Oct 26 HTML / CSS
纯CSS如何禁止用户复制网页的内容
Nov 01 HTML / CSS
box-shadow单边阴影的实现
May 21 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
说说PHP的autoLoad自动加载机制
2012/09/27 PHP
深入PHP nl2br()格式化输出的详解
2013/06/05 PHP
大家须知简单的php性能优化注意点
2016/01/04 PHP
laravel学习笔记之模型事件的几种用法示例
2017/08/15 PHP
PHP回调函数与匿名函数实例详解
2017/08/16 PHP
按给定几率进行随机抽取的js代码
2010/12/28 Javascript
JavaScript中的方法调用详细介绍
2014/12/30 Javascript
所见即所得的富文本编辑器bootstrap-wysiwyg使用方法详解
2016/05/27 Javascript
JavaScript中数组slice和splice的对比小结
2016/09/22 Javascript
ES6学习教程之对象的扩展详解
2017/05/02 Javascript
JS实现留言板功能
2017/06/17 Javascript
Vue学习笔记之表单输入控件绑定
2017/09/05 Javascript
详解使用webpack打包编写一个vue-toast插件
2017/11/08 Javascript
9种改善AngularJS性能的方法
2017/11/28 Javascript
angular.js和vue.js中实现函数去抖示例(debounce)
2018/01/18 Javascript
浅谈React组件之性能优化
2018/03/02 Javascript
JavaScript中Array方法你该知道的正确打开方法
2018/09/11 Javascript
JS实现点击li标签弹出对应的索引功能【案例】
2019/02/18 Javascript
vue移动端屏幕适配详解
2019/04/30 Javascript
深入了解query和params的使用区别
2019/06/24 Javascript
一文秒懂JavaScript构造函数、实例、原型对象以及原型链
2020/08/25 Javascript
深入学习Python中的装饰器使用
2016/06/20 Python
Django基础知识 URL路由系统详解
2019/07/18 Python
在Python中使用MongoEngine操作数据库教程实例
2019/12/03 Python
HTML5 b和i标记将被赋予真正的语义
2009/07/16 HTML / CSS
中国最大的潮流商品购物网站:YOHO!BUY有货
2017/01/07 全球购物
Vero Moda西班牙官方购物网站:丹麦BESTSELLER旗下知名女装品牌
2018/04/27 全球购物
意大利消费电子产品购物网站:SLG Store
2019/12/26 全球购物
运动会入场词50字
2014/02/20 职场文书
婚礼主持词开场白
2014/03/13 职场文书
学生检讨书如何写
2014/10/30 职场文书
2015年工会工作总结
2015/03/30 职场文书
小学体育跳绳课教学反思
2016/02/16 职场文书
vue实现无缝轮播效果(跑马灯)
2021/05/14 Vue.js
linux下导入、导出mysql数据库命令的实现方法
2021/05/26 MySQL
Java 写一个简单的图书管理系统
2022/04/26 Java/Android