好久没写博客了,刚好今天跨年夜没约到什么妹子,在家宅着不如写点东西好了。

需求

昨天晚上,给公司年会做一个移动端的投票页面,遇到一个UI优化的问题:

· 正文内容少于一屏时,投票提交按钮固定显示在页面底部(如图一)
· 正文内容多于一屏时,投票提交按钮,跟随内容,流式显示在内容下面(如图二)
附图:

 

以前做一些管理后台的时候,底部的版权信息声明就是这样的UI需求,实现思路大概就是:
底部按钮,需要一直显示在底部,可以给body设个最小100%高度,然后用绝对定位把按钮显示在body底边靠上一点的位置,这样内容少的时候,100%的高度起作用,按钮会显示在底部,内容多的时候,内容会把body的高度撑出一屏出现滚动条,而按钮是基于body绝对定位,所以可以跟着滚动条走,一直在内容的底部显示。

关键代码就是这样:

html结构:
html>body>.wrap+.bottom-bar html {
height: 100%;
}
body {
min-height: 100%;
position:relative;
}
.bottom-bar {
position: absolute;
bottom: 0px;
}

本以为轻车熟路,5-10分钟搞定的事情,因为一个bfc的问题,我硬生生调了大半夜,现在记录一下。

问题、意外

按照刚才的写法,内容刚好一屏的时候,提交按钮会挡住文档底部的部分内容,所以这里还需要给body设置一个下边距,值要等于bottom-bar的height。
这个时候问题出来了:
body下的子元素的magin-top和margin-bottom值会影响到body的渲染,进而影响到基于body做相对定位的bottom-bar。

调试一番之后,总结了两点特征,就是块级元素&默认情况下&垂直方向的渲染规则:
· 子元素的margin,会影响父元素的UI渲染,父元素不会被子元素的margin想当然地撑开,就是说渲染上,子元素的margin作用在了父元素上
· 父元素的margin会被子元素的覆盖掉,如果父元素magin值比较小的话,表现就是父元素的margin被子元素的吃掉了

此时,不由得想起来CSS2里面非常弯弯绕的一个概念,BFC。

注:如果BFC小测试 这道题能瞬间答对的话,下面的BFC描述可以直接跳过了。

BFC

之前对BFC模式下margin会折叠的理解仅限于兄弟节点之间,没有意识到父子之间也有这类情况。实话说,多数中文的BFC技术文章里讲的,都是在阐述自己的理解或者抄来抄去,有些讲的模棱两可的,恐怕作者自己都没有搞清楚。

先贴一下mdn和w3的文档供大家参考下:
https://developer.mozilla.org/en-US/docs/Web/Guide/CSS/Block_formatting_context
https://www.w3.org/TR/CSS21/visuren.html#block-formatting
https://www.w3.org/TR/CSS21/visuren.html#block-level

备注:· 仔细看看w3的介绍,我相信block containers/block boxes/Block-level elements/block-level box这几个词一定会让你看得想要放弃治疗的,哈哈!
· 另,以上英文文档看得比较费劲的,可以再参考另一位同仁对BFC解释的文章:BFC 神奇背后的原理

再次复习了一下BFC的概念之后,我尝试着总结一下我对这个东西的理解:
1. Block formatting context,是一个上下文环境(可以理解为js里的作用域),这个环境中的元素,遵守块级元素的渲染规则。比如:
  · 从上到下排布,各占一行
  · 垂直方向的margin值,会在相邻节点(兄弟或父子)之间被折叠
  · 自身高度不会被子节点的margin撑大
  · 自身高度不会被浮动子节点撑开
2. 一个默认的html文档流中,只有一个上下文环境
3. 如果需要打破1中所述规则,需要创建一个新的上下文(establish new block formatting contexts for their contents),方法是:
  · 适用于父子/兄弟
    float:left/right、position:absolute、display:非block
  · 仅适用于父子
    overflow:非visible

终极方案

新年快要到了,不多说了,结合以上需求和对BFC的再次理解,直接贴代码:

html结构:
html>body>.wrap+.bottom-bar * {
padding:;
margin:;
}
html {
height: 100%;
overflow: auto;
}
body {
position: relative;
overflow: auto;
min-height: 100%;
}
.wrap {
overflow: auto;/*为了防止子元素对body产生影响,这里需要专门开辟一个新上下文*/
margin-bottom: 40px;/*这里也可以加到body去,body{box-sizing: border-box;padding-bottom:40px;}*/
}
.bottom-bar {
position: absolute;
bottom: 0px;
height: 40px;
width: 100%;
}

“fixed+relative==absolute”——对BFC的再次思考的更多相关文章

  1. “fixed+relative≈≈absolute”——对BFC的再次思考

    好久没写博客了,刚好今天跨年夜没约到什么妹子,在家宅着不如写点东西好了. 需求 昨天晚上,给公司年会做一个移动端的投票页面,遇到一个UI优化的问题: · 正文内容少于一屏时,投票提交按钮固定显示在页面 ...

  2. /*透明度设置的两种方式,以及hover的用法,fixed,(relative,absolute)这两个一起用*/

    <!DOCTYPE html> /*透明度设置的两种方式,以及hover的用法,fixed,(relative,absolute)这两个一起用*/ <html lang=" ...

  3. css属性position: static|relative|absolute|fixed|sticky简单解析

    目录 static 静态定位(默认) relative 相对定位 正常文档流 加了relative之后的布局 加上margin/padding/border之后的布局 absolute 绝对定位 正常 ...

  4. Position属性四个值:static、fixed、absolute和relative的区别和用法

    Position属性四个值:static.fixed.absolute和relative的区别和用法 在用CSS+DIV进行布局的时候,一直对position的四个属性值relative,absolu ...

  5. css position static | absolute | fixed | relative

    <div id="bigbox1">    <div id="box1" class="box">box1</ ...

  6. CSS position relative absolute fixed

    position属性absolute与relative 详解   最近一直在研究javascript脚本,熟悉DOM中CSS样式的各种定位属性,以前对这个属性不太了解,从网上找到两篇文章感觉讲得很透彻 ...

  7. What is the difference between position: static,relative,absolute,fixed

    What is the difference between static,relative, absolute,fixed we can refer to this link: expand

  8. z-index的理解 z-index 属性仅在节点的 position 属性为 relative, absolute 或者 fixed 时生效.

    今天做游戏的Exercise模式的时候,发现把所有的div设置为position:absolute;后,点击play进入到游戏界面的时候,鼠标点击数字的时候,完全没反应.经过我的反复检查,发现只要给所 ...

  9. css的定位,relative/absolute/fixed的用法

    其实position的值有四个,static/relative/absolute/fixed,而static是默认值,不算具有有定位属性,这里就不讲了. 定位其实就是跟元素设置定位属性,然后设置其对位 ...

随机推荐

  1. 背后的故事之 - 快乐的Lambda表达式(一)

    快乐的Lambda表达式(二) 自从Lambda随.NET Framework3.5出现在.NET开发者眼前以来,它已经给我们带来了太多的欣喜.它优雅,对开发者更友好,能提高开发效率,天啊!它还有可能 ...

  2. ABP文档 - 通知系统

    文档目录 本节内容: 简介 发送模式 通知类型 通知数据 通知重要性 关于通知持久化 订阅通知 发布通知 用户通知管理器 实时通知 客户端 通知存储 通知定义 简介 通知用来告知用户系统里特定的事件发 ...

  3. css3中perspective

    perspective 属性定义 3D 元素距视图的距离,以像素计.该属性允许改变 3D 元素查看 3D 元素的视图.当为元素定义 perspective 属性时,其子元素会获得透视效果,而不是元素本 ...

  4. 比Mysqli操作数据库更简便的方式 。PDO

    下面来说一下PDO 先画一张图来了解一下 mysqli是针对mysql这个数据库扩展的一个类 PDO是为了能访问更多数据库 如果出现程序需要访问其他数据库的话就可以用PDO来做 PDO数据访问抽象层1 ...

  5. Web APi之认证(Authentication)两种实现方式【二】(十三)

    前言 上一节我们详细讲解了认证及其基本信息,这一节我们通过两种不同方式来实现认证,并且分析如何合理的利用这两种方式,文中涉及到的基础知识,请参看上一篇文中,就不再叙述废话. 序言 对于所谓的认证说到底 ...

  6. 微框架spark--api开发利器

    spark简介 Spark(注意不要同Apache Spark混淆)的设计初衷是,可以简单容易地创建REST API或Web应用程序.它是一个灵活.简洁的框架,大小只有1MB.Spark允许用户自己选 ...

  7. 云瓣影音网站&&微信端(已开源)

    随着该项目的发布到线上(小打小闹),即将又要开启另一段崭新的旅程.强迫自己停下来写写所学所得,个人认为总结和分享是一种很棒的学习方式.那让我们先来瞧瞧项目长的什么样.如果着急要源码的朋友,可以下拉到最 ...

  8. 2016/12/31_Python

    今天学习主要内容: Python: 1.with语句(补充昨天的文件操作) 用with打开的文件在脚本结束会自动关闭,以防普通打开方式忘记关闭文件连接 语法: with open("demo ...

  9. MyBatis源码分析(一)开篇

    源码学习的好处不用多说,Mybatis源码量少.逻辑简单,将写个系列文章来学习. SqlSession Mybatis的使用入口位于org.apache.ibatis.session包中的SqlSes ...

  10. Android之网络数据存储

    一.网络保存数据介绍 可以使用网络来保存数据,在需要的时候从网络上获取数据,进而显示在App中. 用网络保存数据的方法有很多种,对于不同的网络数据采用不同的上传与获取方法. 本文利用LeanCloud ...