什么是BFC?

1. bfc的概念

BFC(Block formatting context),即块级格式化上下文,它作为 HTML 页面上的一个独立渲染区域,只有区域内元素参与渲染,且不会影响其外部元素。

W3C 对 BFC 的定义如下:

浮动元素和绝对定位元素,非块级盒子的块级容器(例如 inline-blocks,table-cells 和 table-captions),以及 overflow 值不为 “visiable” 的块级盒子,都会为他们的内容创建新的 BFC(块级格式上下文)。

2. 如何创建bfc,即bfc的触发条件

- 根元素,即 HTML 元素。
- 浮动元素,float 除了 none 以外的值。
- 定位元素,position 的值为 absolute 或 fixed,不是 static 或者 relative。
- display 的值是 inline-block、table-cell、flex、table-caption或者 inline-flex 。
- overflow 除了 visible 以外的值(hidden,auto,scroll )。

只要满足上述 5 个 CSS 条件之一即可。

3. bfc的布局规则

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

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

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

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

- BFC 的区域不会与 float box重叠(可以用此来解决自适应布局的问题)。

- 计算 BFC 的高度时,浮动元素也参与计算(撑开父元素,不会出现高度塌陷问题)。

4. bfc的应用
 

(1)避免外边距重叠(防止margin塌陷)

根据 BFC 布局规则:

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

折叠的结果:

        两个相邻的外边距都是正数时,折叠结果是它们两者之间的较大值
        两个相邻的外边距都是负数时,折叠结果是两者绝对值的较大值
        两个外边距一正一负时,折叠结果是两者的相加的和


解决方法:

        当两个相邻块级子元素分属于不同的 BFC 时,就可以阻止margin 重叠。


操作方法:

        给其中一个 p 外面包一个 div,然后通过触发外面这个 div 的 BFC,就可以阻止这两个 p 的 margin 重叠。

(2) 清除浮动

        浮动元素是会脱离文档流的(绝对定位元素会脱离文档流)。

        如果一个没有高度或者 height 是 auto 的容器的子元素是浮动元素,则该容器的高度是不会被撑开的。我们通常会利用伪元素(:after或者:before)来解决这个问题。

        通过给父元素设置BFC属性,来实现清除浮动,从而解决容器高度不会被撑开的问题。

<div class="container">
    <div>内容1</div>
    <div>内容2</div>
</div>
 <style>
     .container {
         /* 创建了一个BFC */
         overflow: hidden;
         background-color: skyblue;
     }
     .container div {
         float: left;
         background-color: steelblue;
         margin: 10px;
     }
 </style>

拓展1:清除浮动的方法的四种方式

当容器的高度为auto,且容器的内容中有浮动(float为left或right)的元素,在这种情况下,容器的高度不能自动伸长以适应内容的高度,使得内容溢出到容器外面而影响(甚至破坏)布局的现象。这个现象叫浮动溢出,为了防止这个现象的出现而进行的CSS处理,就叫CSS清除浮动。

    <div class="father">
      <div class="box1">1</div>
      <div class="box2">2</div>
    </div>
 

1)给父元素添加高度

父元素高度的设置一定要大于子元素中高度最高的盒子

<style>
    .father{
      width: 100%;
      height: 100px;
      border: 2px solid red;
    }
</style>

2)给父元素设置overflow:hidden

<style>
   .father{
      width: 100%;
      border: 2px solid red;
      overflow: hidden;
    }
</style>

3)添加空标签:clear:both

在需要清除浮动的标签后面添加一个空标签,给其加上clear:both

    <div class="father">
      <div class="box1">1</div>
      <div class="box2">2</div>
      <div class="clear"></div>
    </div>
    
    <script>
       .clear{
          clear: both;
        }
    </script>

4)使用after伪元素清除浮动 

<style>
  .father:after{
    content: "";
    display: block;
    height: 0;
    clear:both;
    visibility: hidden;
}
.father{
    zoom: 1;
   /*IE6清除浮动的方式 只有IE6-IE7执行,其他浏览器不执行*/
}
 
</style>

(3)实现两栏布局

// HTML代码
 <div class="box">
     <div class="left">左边固定宽度为200px</div>
     <div class="right">右边自适应</div>
 </div>

// CSS代码
<style>
    .box {
        background-color: pink;
        height: 300px;
    }
    .left {
        float: left;
        width: 200px;
        height: 200px;
        background-color: royalblue;
    }
    .right {
        height: 300px;
        background-color: skyblue;
    }
</style>

效果如图

 

因为BFC 的区域不会与 float box 重叠,所以我们让 right 单独成为一个 BFC,right 会自动的适应宽度,这样就可以实现自适应两栏布局效果了

 <style>
     .box {
         background-color: pink;
         height: 300px;
     }
     .left {
         float: left;
         width: 200px;
         height: 200px;
         background-color: royalblue;
     }
     .right {
         /* 创建了一个BFC */
         overflow: hidden;
         height: 300px;
         background-color: skyblue;
     }
 </style>

效果如图

 

拓展2:CSS中常见的布局方案

  · 普通流定位
            1.元素按照其在HTML中的先后位置至上而下进行布局
            2.行内元素水平排列,直至当行被占满然后换行,块级元素则会被渲染为完整的一整行
            3.所有元素默认都是普通流定位
 · 浮动 float
            元素首先按照普通流的位置出现,然后根据浮动的方向尽可能向左或向右偏移
  · 绝对定位 position
            元素整体会脱离普通流,因此绝对定位的元素不会对兄弟元素造成影响

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
HTML、CSS、JavaScript是Web开发中的三个核心技术。HTML是超文本标记语言,用于描述网页内容;CSS是层叠样式表,用于描述网页布局和样式;JavaScript是用于网页交互和动态效果的脚本语言。 盒模型是指在Web开发中,每个元素可以看做是一个矩形的盒子,包含内容区域、内边距、边框和外边距四部分。有两种盒模型,分别是标准盒模型和IE盒模型。标准盒模型的宽度和高度只包括内容区域,而IE盒模型的宽度和高度包括了内容区域、内边距和边框。设置盒模型的方式是通过CSS的box-sizing属性,可以设置为content-box(标准盒模型)或border-box(IE盒模型)。 CSS选择器用于选择需要样式化的HTML元素。常见的选择器有标签选择器、类选择器、ID选择器、后代选择器、子元素选择器等。优先级是指当多个选择器应用到同一个元素时,哪一个选择器的样式会被应用。优先级的计算方式是通过不同选择器的权重来计算的,权重越高的选择器优先级越高。 要居中一个元素,可以使用CSS的flex布局或者绝对定位。使用flex布局时,设置父元素的display属性为flex,同时设置justify-content和align-items属性为center。使用绝对定位时,设置父元素的position属性为relative,子元素的position属性为absolute,同时设置left和top属性为50%。 清除浮动是指当一个元素设置了浮动后,会导致其父元素高度塌陷,无法撑开父元素。可以通过在父元素中添加一个clearfix类来清除浮动,或者使用CSS的overflow属性将父元素设置为auto或hidden。 BFC(块级格式化上下文)是指一个独立的渲染区域,可以防止元素间的margin重叠,并且可以自动适应父元素的宽度。应用场景包括浮动元素、定位元素、inline-block元素等。 CSS3新增了很多新特性,包括圆角、阴影、渐变、变形、动画、媒体查询等。 响应式设计是指根据用户使用设备的不同,自适应地改变网页的布局和样式。实现方式包括使用CSS的媒体查询、弹性布局、流式布局等。 跨域是指在同一域名下的网页请求其他域名下的资源。解决跨域问题的方式包括JSONP、CORS、代理等。 HTTP状态码是指在HTTP协议中,服务器响应客户端请求时返回的状态码。常见的状态码包括200 OK、404 Not Found、500 Internal Server Error等。 事件冒泡和事件捕获是指在DOM中,当一个事件被触发时,会从最内层的元素开始,逐级向外层元素冒泡或者向内层元素捕获。可以使用事件对象的stopPropagation方法来阻止事件冒泡或者捕获。 闭包是指函数和其相关的引用环境组合而成的实体,可以访问其定义时的变量。闭包的作用包括保护变量、模块化编程、实现私有变量等。 ES6新增了很多新特性,包括let、const、箭头函数、模板字符串、解构赋值、Promise等。 实现异步编程的方式包括回调函数、Promise、async/await等。 React的生命周期包括componentDidMount、componentWillUnmount、shouldComponentUpdate等,在组件的不同阶段会触发不同的生命周期函数,可以在这些函数中进行状态管理和数据处理。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值