CSS布局相关基本概念

2017-11-22  本文已影响0人  744354889606

主要参考文档:
http://www.zhangxinxu.com/wordpress/2015/02/css-deep-understand-flow-bfc-column-two-auto-layout/
https://www.cnblogs.com/dojo-lzz/p/3999013.html

测试例子:
https://codepen.io/icyfanfan/pen/yPvGQR
https://codepen.io/icyfanfan/pen/BmOOZv

理解文档流对于理解CSS布局其他相关概念很重要!!

文档流

基于文档流,理解定位模式:

相对定位, 即相对于元素在文档流中位置进行偏移。 但保留原占位。
绝对定位, 即完全脱离文档流, 相对于position属性非static值的最近父级元素进行偏移。
固定定位, 即完全脱离文档流, 相对于视区进行偏移

块级元素 BLOCK-LEVEL ELEMENT

标签:div
特点:

块状元素的流体特性
块状水平元素,如div元素,在默认情况下(未定义宽度、非浮动绝对定位等),水平方向会自动填满外部的容器;如果有margin-left/margin-right, padding-left/padding-right, border-left-width/border-right-width等,实际内容区域会响应变窄。

内联元素 INLINE ELEMENT

标签:span
特点:

内联块级

display: inline-block
特点:

Formatting Context:指页面中的一个渲染区域,并且拥有一套渲染规则,他决定了其子元素如何定位,以及与其他元素的相互关系和作用。

BFC-BLOCK FORMATTING CONTEXT 块级格式化上下文

BFC元素特性表现原则就是,内部子元素再怎么翻江倒海,翻云覆雨都不会影响外部的元素 - 所以,避免margin穿透啊,清除浮动什么的也好理解了 - from 张鑫旭blog原话
理解:一个独立的块级渲染区域,只有Block-level box参与,该区域拥有一套渲染规则来约束块级盒子的布局,内部布局不会受外部影响也不会对外部产生影响

如何产生BFC:

BFC规则

分析:

  1. 内部的Box会在垂直方向上一个接一个的放置
  2. 垂直方向上的距离由margin决定。(完整的说法是:属于同一个BFC的两个相邻Box的margin会发生重叠,与方向无关。)
  3. 每个元素的左外边距与包含块的左边界相接触(从左向右),即使浮动元素也是如此。(这说明BFC中子元素不会超出他的包含块,而position为absolute的元素可以超出他的包含块边界)
  4. BFC的区域不会与float的元素区域重叠
  5. 计算BFC的高度时,浮动子元素也参与计算
  6. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面元素,反之亦然

借此回忆一下之前学习过的一些布局知识
垂直方向上,两个相邻div margin重叠:其实是在同一个bfc环境中
设置父元素overflow:hidden或浮动父元素能清除浮动影响:其实就是使父元素触发bfc,让子元素参与父元素的高度计算

BFC应用
防止margin重叠:将发生重叠的元素放到两个BFC中(或者使其中一个产生BFC)
清除浮动:略
布局:利用BFC区域不会与float元素区域重叠的特性,便于实现多栏布局

上一篇 下一篇

猜你喜欢

热点阅读