关于CSS里的块级格式


本文摘自PHP中文网,作者php中世界最好的语言,侵删。

1.BFC 定义

BFC(Block formatting context)直译为"块级格式化上下文"。它是一个独立的渲染区域,只有Block-level box(块级元素)参与, 它规定了内部的Block-level Box如何布局,并且与这个区域外部毫不相干.

通俗地来说:创建了 BFC的元素就是一个独立的盒子,里面的子元素不会在布局上
影响外面的元素(里面怎么布局都不会影响外部),BFC任然属于文档中的普通流

2.BFC的生成:

知道了BFC怎么触发BFC
满足以下条件之一都可以触发BFC,变身为BFC

根元素

float属性不为none

position不为static和relative

overflow不为visible

display为inline-block, table-cell, table-caption, flex, inline-flex

你会发现BFC无处不在,只是自己用的时候不知道而已

3.BFC布局规则:

变身为BFC后有什么特性呢,以下:

内部的Box会在垂直方向,一个接一个地放置。

Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠

每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。

BFC的区域不会与float box重叠。

BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。

计算BFC的高度时,浮动元素也参与计算

4.BFC作用:

用起来come boby

1.防止外边距重叠

bfc导致的属于同一个bfc中的子元素的margin重叠(Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠)

问题:由图可以看到,String1和String2 之间只有20px的margin,按理来说应该是40px,但这是在bfc中导致了他们的margin重叠


代码:

1

2

3

4

5

6

7

8

9

10

11

12

<style>.container1{

        /* 通过overflow:hidden可以创建bfc */

        overflow: hidden;

        background-color: red;

        width: 300px;

    }

    .sub1{

        margin: 20px 0px;

        background-color: #dea;

    }</style><div class="container1">

        <div class="sub1">String1</div>

        <div class="sub1">String2</div></div>

解决方法:我们可以在div外面包裹一层容器,并触发该容器生成一个BFC。那么两个div便不属于同一个BFC,就不会发生margin重叠了。


代码:

1

2

3

4

5

6

<style>

    .newbfc{

            overflow: hidden;

    }</style><div class="container1">

        <div class="sub1">String1</div>

        <div class="newbfc"><div class="sub1">String2</div></div></div>

2.清除浮动:

问题:当元素的子元素都浮动后,会出现高度坍塌的现象,即父容器的高度不会被撑开


代码:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

<style>

    .pre2{

        width: 200px;

        border: 2px solid red;

    }

    .float1,.float2{

        width: 100px;

        height: 100px;

        float: left;

    }

    .float1{

        background-color: #dee;

    }

    .float2{

        background-color: #dcc;

    }</style><div class="pre2">

        <div class="float1"></div>

        <div class="float2"></div></div>

解决方法:

bfc的规则:计算BFC的高度时,浮动元素也参与计算所以只要将父容器设置为bfc就可以把子元素包含进去:
这个容器将包含浮动的子元素,它的高度将扩展到可以包含它的子元素,在这个BFC,这些元素将会回到页面的常规文档流。

1

2

3

4

5

6

.pre2{

        width: 200px;

        border: 2px solid red;

        /* 设置overflow*/

        overflow:hidden;

    }

3.解决布局:防止文字环绕


代码:

1

2

3

4

5

6

7

8

9

10

11

12

<style>.container2{

        overflow: hidden;

        width: 200px;

    }

    .box{

        float: left;

        width: 100px;

        height: 30px;

        background-color: #daa;

    }</style><div class="container2">

        <div class="box"></div>

        <p style="background-color: #eea">sdfadsfdff fffffffds fsfffff sfd  fsdsdfsdf fffffff</p></div>

这个p元素并没有移动,但是它却出现在浮动元素的下方。p元素的line boxes(指的是文本行)进行了移位。此处line boxes的水平收缩为浮动元素提供了空间。

bfc的规则:每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。

解决这个问题只要将p元素添加overflow:hidden使其成为一个新的bfc就可以了

相信看了这些案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

相关阅读:

HTML中划分框窗有哪些常用属性

在HTML中有哪些引用CSS的方式

iframe的去边框和无边框有哪些操作方式

以上就是关于CSS里的块级格式的详细内容,更多文章请关注木庄网络博客

相关阅读 >>

css伪类分为哪几种

css怎么设置margin

为什么外接css不起作用

css图片怎么设置透明度

css怎么设置文本框宽度

css怎么给表格设置边框

html中弹性布局(flex)的介绍(附代码)

css超链接如何去掉下划线

css怎么实现字体描边效果

css中有哪些属性可以继承

更多相关阅读请进入《样式表》频道 >>




打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,您说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

分享从这里开始,精彩与您同在

评论

管理员已关闭评论功能...