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

需求

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

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

 

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

关键代码就是这样:

  1. html结构:
  2. html>body>.wrap+.bottom-bar
  3.  
  4. html {
  5. height: 100%;
  6. }
  7. body {
  8. min-height: 100%;
  9. position:relative;
  10. }
  11. .bottom-bar {
  12. position: absolute;
  13. bottom: 0px;
  14. }

本以为轻车熟路,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的再次理解,直接贴代码:

  1. html结构:
  2. html>body>.wrap+.bottom-bar
  3.  
  4. * {
  5. padding:;
  6. margin:;
  7. }
  8. html {
  9. height: 100%;
  10. overflow: auto;
  11. }
  12. body {
  13. position: relative;
  14. overflow: auto;
  15. min-height: 100%;
  16. }
  17. .wrap {
  18. overflow: auto;/*为了防止子元素对body产生影响,这里需要专门开辟一个新上下文*/
  19. margin-bottom: 40px;/*这里也可以加到body去,body{box-sizing: border-box;padding-bottom:40px;}*/
  20. }
  21. .bottom-bar {
  22. position: absolute;
  23. bottom: 0px;
  24. height: 40px;
  25. width: 100%;
  26. }

“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. IIS查找报错信息

    1.打开IIS,选择日志 2.选择 日志文件和ETW事件   ---->应用 3.在发布网站的根目录下找一个logs文件(如果没有则创建) 4.浏览网站,如果报错,logs文件夹下面就会生成一个 ...

  2. 使用idea开发分布式项目中优化tomact的方法

    1. idea内存优化 找到idea安装目录,我的是在D:\IDEA\bin目录中 找到idea.exe.vmoptions和idea64.exe.vmoptions文件 这两个文件全部改成如下配置, ...

  3. Java环境配置:MacOS

    主要是在mac os下进行java环境配置. 下载jdk http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads- ...

  4. 优化剪枝搜索——牛客多校第二场F

    试了很多种爆搜和剪枝,最后发现还是状压的比较好用 #include <bits/stdc++.h> using namespace std; // #define IO #define f ...

  5. NX二次开发-UFUN获取NX系统默认导出CGM的选项设置UF_CGM_ask_default_export_options

    文章转载自唐康林NX二次开发论坛,原文出处: http://www.nxopen.cn/thread-126-1-1.html 刚才有同学问到这个问题,如果是用NXOpen来做,直接录制一下就可以了: ...

  6. Delphi 中的哈希表: THashedStringList

    转自万一博客 Delphi 中的哈希表: THashedStringList unit Unit1; interface uses   Windows, Messages, SysUtils, Var ...

  7. tensorflow TypeError: Can not convert a float32 into a Tensor or Operation

    遇到这种情况可能是你的程序中有和你定义的tensor 变量重名的其他变量名字,jishi在for循环中使用了这个名字的作为临时变量也不行.tenor 变量很娇气.坑了我一晚上的时间. 比如:x = t ...

  8. 引入css文件时,css link和@import区别

    这里link与@import介绍的是html引入css的语法单词.两者均是引入css到html的单词. 一.了解基本 1.link语法结构 <link href="CSSurl路径&q ...

  9. libgdx 启动者(个人翻译,还请不吝赐教)类和配置

    本文章翻译自libGDX官方wiki,.转载请注明出处:http://blog.csdn.net/kent_todo/article/details/37942047 libGDX官方网址:http: ...

  10. hadoop系列(一)window10下hadoop安装

    风闻win10不需要cygwin就能用hadoop了,赶紧试试. 去官网下载hadoop-2.8.3,然后去 https://github.com/steveloughran/winutils 下载h ...