• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >CSS > CSS使用BFC规则布局引发外层div包裹内层div的处理方法

CSS使用BFC规则布局引发外层div包裹内层div的处理方法

作者:Aaron 字体:[增加 减小] 来源:互联网 时间:2017-08-06

本文主要包含CSS,BFC,div,浮动等相关知识,Aaron 希望在学习及工作中可以帮助到您

BFC的概念
BFC全称Block Formatting Context ,直译“块级格式化上下文”,也有译作“块级格式化范围”。它是 W3C CSS 2.1 规范中的一个概念,它决定了元素如何对其内容进行定位,以及与其他元素的关系和相互作用。通俗的讲,就是一个div内部,我们用float和margin布局元素。

BFC布局规则:
1.内部的Box会在垂直方向,一个接一个地放置。
2.Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠
3.每个元素的margin box的左边, 与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。
4.BFC的区域不会与float box重叠。
5.BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。
6.计算BFC的高度时,浮动元素也参与计算

创建一个BFC
一个BFC可以被显式的触发。如果想要创建一个新的BFC,只需要给它添加上面提到的任何一个CSS样式就可以了。
例如,请看下面的 HTML :

  1. <div class="container">  
  2.     Some Content here   
  3. </div>  

一个新的BFC可以通过给容器添加任何一个触发BFC的CSS样式,如 overflow: scroll , overflow: hidden , display: flex , float: left ,或者 display: table 来创建。
display:table 可能会产生一些问题
overflow:scroll 可能会显示不必要的滚动条
float:left 将会把元素置于容器的左边,其他元素环绕着它
overflow:hidden 将会剪切掉溢出的元素
所以每当想要创建一个新的BFC的时候,我们会基于我们的需求选择最好的样式条件。为了一致性,我在这篇文章所给出的例子中全部使用了 overflow: hidden

  1. container {   
  2.     overflow: hidden;   
  3. }  

你可以自由使用除了 overflow: hidden 之外的样式声明。

BFC布局引发的问题
我们看看BFC布局引发的问题吧。
例如如下代码

  1. <!doctype html>   
  2. <html lang="en">   
  3. <head>   
  4.     <meta charset="UTF-8">   
  5.     <title>Clear float</title>   
  6.     <style type="text/css">   
  7.         .container{   
  8.             margin: 30px auto;   
  9.             width:600px;   
  10.             height: 300px;   
  11.         }   
  12.         .p{   
  13.             border:solid 3px #a33;   
  14.         }   
  15.         .c{   
  16.             width: 100px;   
  17.             height: 100px;   
  18.             background-color: #060;   
  19.             margin: 10px;   
  20.             float: left;   
  21.         }   
  22.     </style>   
  23. </head>   
  24. <body>   
  25.     <div class="container">   
  26.         <div class="p">   
  27.             <div class="c"></div>   
  28.             <div class="c"></div>   
  29.             <div class="c"></div>   
  30.         </div>   
  31.     </div&

您可能想查找下面的文章:

  • css小技巧
  • 各大网站CSS初始化代码
  • css权重问题
  • CSS实现鼠标上移图标旋转效果
  • 使用CSS3制作一个简单的进度条(demo)
  • 用纯CSS实现饼状Loading等待图效果
  • 利用CSS3伪元素实现逐渐发光的方格边框
  • CSS3实现内凹圆角的实例代码
  • 利用HTML5+CSS3实现3D转换效果实例详解
  • css3+伪元素实现鼠标移入时下划线向两边展开的效果

相关文章

  • 2017-08-06CSS属性探秘系列(三):line-height
  • 2017-08-06css控制表格细边框样式
  • 2017-08-06IE6,IE7浏览器下 margin 无效的解决方法
  • 2017-08-06CSS3正方体旋转示例代码
  • 2017-08-0627款经典的CSS框架小结 网页制作必备
  • 2017-08-06css关于position属性的用法详解(绝对定位和相对定位的混淆)
  • 2017-08-06css3新增颜色表示方式分享
  • 2017-08-06浅谈CSS字体的加载加速问题
  • 2017-08-06CSS样式分离之再分离达到精简与重用
  • 2017-08-06纯CSS3实现的阴影效果

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • css属性让网页文字实现竖排的几种方法
    • CSS3制作炫酷的下拉菜单及弹起式选单的实例分享
    • 谈谈CSS的边距合并之我的理解
    • 关于clearBoth在GOOGLE Chrome中的问题解决方法
    • 针对IE浏览器的兼容问题小结
    • 分享CSS3中必须要知道的10个顶级命令
    • 完整css选择器总结
    • 学习DIV+CSS网页布局之混合布局
    • CSS 鼠标样式和手指样式整理
    • 纯CSS实现Lavalamp效应的滑动菜单效果

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有