格式化上下文杂谈


皇帝的金斧头
我基本对css没有系统的学习,都是在平常中写html与js中积累下来的知识,如有错误,希望能提出,同时有疑惑可以交流,下文是我看了4天bfc中浓缩的观点。
布局的思考
布局主要通过定位体系实现,定位体系决定着框的摆放。一门语言就像一种工具,不但能干活,人用着得舒服,总不能制作一个扳手,你往左扳,螺丝向右旋吧。
对css的定位体系来说,三种定位方式就是工具,使框能摆放到需要的位置,实现了布局,常规流定位使元素自动流动到所需位置,浮动使周围元素环绕,绝对定位硬性规定元素的位置。通过定位机制,元素能摆放到某个位置。这是能干活了,但是,有时候用着却不舒服。

图1-1

图片1-1

如图1-1,发现box_2的布局与box_1存在了margin,但是也受到box子元素inner的影响。这个就不符合人类直觉了,明明代码存在了层次关系,但实现时子元素作为浮动元素,溢出了父元素的框架,对页面其他元素造成影响。所以必须对定位体系进行改进以实现可控且清晰的布局。所以就引入了bfc的概念,在很多文章中都是把bfc形容成一个容器,容器内外元素互不干扰。所以进行容器布局时,只需考虑父子、兄弟关系了,


以下是一些个人分析,适合有bfc基础的同学思考。
我认为规则就只有两点:
1、bfc元素是容器,那必定会产生隔离,隔离是对子元素的隔离,所以子元素的margin不与容器margin合并;
2、bfc不会发生框重叠;兄弟关系的两个bfc,如果其中存在浮动框,就左右摆放,如果是父子关系的两个bfc,就通过包含关系,所以这就是bfc能计算框内浮动元素高度的原因了。
其他bfc的规则,你不难发现其实是常规流的布局规则,因为bfc也是属于常规流,继承规则的同时进行了扩展。
可能有些同学对bfc的margin合并存在理解的偏差,可看如何解决外边距叠加的问题这个讨论,一定要看评论的内容,看完基本不难理解bfc与margin合并这两个概念了。


每日小问
2016年1月1日23:15:06

#div1{width: 200px; height: 200px;overflow:hidden;margin:20px;background:#AA0;}
#div2{width:200px; height: 200px;overflow:hidden;margin:20px;background:#0AA;}
<div id='div1'></div>
<div id='div2'></div>

这里两个div间距离多少,为什么?

#container{width: 300px;height: 300px;float: left;}
#div1{width: 200px; height: 200px;float: left;;margin:20px;background:#AA0;}
#div2{width:200px; height: 200px;float: left;;margin:20px;background:#0AA;}
<div id='container'>
    <div id='div1'></div>
    <div id='div2'></div>
</div>

这里两个div间距离多少,为什么?

答案在明天的文章中。


欢迎指出文章的错误,如有对文章观点有疑惑希望能提出互相交流。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 159,015评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,262评论 1 292
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,727评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,986评论 0 205
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,363评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,610评论 1 219
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,871评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,582评论 0 198
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,297评论 1 242
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,551评论 2 246
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,053评论 1 260
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,385评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,035评论 3 236
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,079评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,841评论 0 195
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,648评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,550评论 2 270

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,629评论 1 92
  • 什么是BFC BFC全称是Block Formatting Context,即块格式化上下文。它是CSS2.1规范...
    clfeng阅读 415评论 0 0
  • relative:生成相对定位的元素,通过top,bottom,left,right的位置相对于其正常位置进行定位...
    zx9426阅读 911评论 0 2
  • 一、BFC是什么? 它是 Block Formatting Context (块级格式化上下文) 的简称,接下来通...
    07120665a058阅读 3,720评论 15 40
  • BFC(块级格式化上下文) @(CSS)[CSS|BFC] [TOC]已经是一个耳听熟闻的词语了,网上有许多关于 ...
    dr2009阅读 17,694评论 3 61