BFC块级格式化上下文的方法

本篇内容主要讲解“BFC块级格式化上下文的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“BFC块级格式化上下文的方法”吧!

创新互联公司专业为企业提供陵城网站建设、陵城做网站、陵城网站设计、陵城网站制作等企业网站建设、网页设计与制作、陵城企业网站模板建站服务,十余年陵城做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。

BFC概念

BFC即Block Formatting Contexts(块级格式化上下文),它是W3C CSS2.1 规范中的一个概念。它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素将如何定位,以及和其他元素的关系和相互作用。

具有BFC特性的元素可以看作是隔离了的独立容器,容器里面的元素不会在布局上影响到外面的元素,并且BFC具有普通容器所没有的一些特性。

通俗一点来讲,可以把BFC理解为一个封闭的大箱子,箱子内部的元素无论如何翻江倒海,都不会影响到外部。

BFC触发条件

满足以下条件之一,即可触发BFC:

float的值不是none

position的值不是static或者relative

display的值是inline-block、table-cell、flex、table-caption或者inline-flex

overflow的值不是visible

下面的box盒子就是一个BFC独立容器:

.box{

width: 100px;

height: 100px;

overflow: hidden;   /* 触发了BFC,形成独立盒子 */

}

BFC的应用

在前面介绍盒模型的margin时,出现了传递和叠加的问题,这里可以采用BFC规范来解决,原理就是让盒子形成一个独立的容器,无论里面的子元素如何折腾,都不影响到外面的元素。

<style>

.box1 {

width: 200px;

height: 200px;

background: pink;

overflow: hidden;    /* 触发了BFC,形成独立盒子 */

}

.box2{

width: 100px;

height: 100px;

background: skyblue;

margin-top: 30px;

}

</style>

<div class="box1">

<div class="box2"></div>

</div>

BFC解决传递问题

<style>

section{

overflow: hidden;    /* 触发了BFC,形成独立盒子 */

}

.box1 {

width: 200px;

height: 200px;

background: pink;

margin-bottom: 40px;

}

.box2 {

width: 100px;

height: 100px;

background: skyblue;

margin-top: 30px;

}

</style>

<section>

<div class="box1"></div>

</section>

<section>

<div class="box2"></div>

</section>

BFC解决叠加问题

BFC还可以解决前面浮动遇到了父容器高度塌陷的问题,也就是不管里面子元素是否浮动,都不会因为脱离文档流对容器高度造成影响。

<style>

.box1 {

width: 200px;

border: 1px black solid;

overflow: hidden;     /* 触发了BFC,形成独立盒子 */

}

.box2 {

width: 100px;

height: 100px;

background: pink;

float: left;

}

</style>

<div class="box1">

<div class="box2"></div>

</div>

到此,相信大家对“BFC块级格式化上下文的方法”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!

文章题目:BFC块级格式化上下文的方法
转载注明:https://www.cdcxhl.com/article38/joddsp.html

成都网站建设公司_创新互联,为您提供网站内链全网营销推广网页设计公司定制网站用户体验小程序开发

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都app开发公司