- 1、本文档共9页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
ICSS中BFC的理解
BFC是什么
Block Formatting Context (块格式化上下文)是 W3C CSS 2.1 规范中的一个概念,在CSS3中被修改为flow root。格式化则表明了在这个环境中,元素处于此环境中应当被初始化,即元素在此环境中应当如何布局等。元素如果创建了BFC,那么BFC决定了如何对其内容进行定位,以及它与其他元素的关系和相互作用。创建了BFC的元素会按照如下的方式对其子元素进行排列:
元素的子元素会一个接一个地放置。垂直方向上他们的起点是一个包含块的顶部,两个相邻的元素之间的垂直距离取决于 margin 特性。在 BFC中相邻的块级元素的垂直边距会折叠(collapse)。
元素的子元素中,每一个子元素左外边与包含块的左边相接触(对于从右到左的格式化,右外边接触右边), 即使存在浮动也是如此(尽管一个子元素的内容区域会由于浮动而压缩),除非这个子元素也创建了一个新的BFC,如它自身也是一个浮动。
如对于如下的HTML页面:
class=father的div为创建了新的BFC的容器,它的两个子元素的起始都是从容器的最左边开始的,尽管第一个div为浮动,且占据了它的部分空间。如红色背景色为p的区域。而第二个子div,由于其的浮动设为向右浮动,因此它也创建了一个BFC
什么情况下会创建BFC
CSS 规范说明了在下列这些情况下会创建新的 block formatting context:
浮动元素(float: left | right);
绝对定位元素(position: absolute | fixed);
行内块元素(display: inline-block);
表格的单元格(display: table-cells,TD、TH);
表格的标题(display: table-captions,CAPTION);
overflow 特性不为 visible 的元素(除非该值已经传播到viewport?);
表格元素创建的 匿名框
注意,display:table 本身并不产生 block formatting contexts。但是,它可以产生匿名框 6, 其中包含 display:table-cell 的框会产生块格式化上下文。 总之,对于 display:table 的元素,产生块格式化上下文的是匿名框而不是 display:table
注意,是这些元素创建了块格式化上下文,它们本身不是块格式化上下文。
BFC的主要特性
BFC的主要用处是清除浮动,以及实现多栏布局
创建了 BFC 的元素中,子浮动元素也会参与高度的计算,即不会发生高度‘塌陷’,可以利用这个特性来实现清除浮动的功能
Container 的高度值为 auto,并且 overflow 的值为hidden;即Container 创建 block formatting context。
SPAN1 是一个行内元素, DIV1 是一个处于普通流中的块元素;
DIV2 是一个浮动的块级元素。
而如果去掉Container的overflow:hidden,即恢复其默认值为overflow:visible,它变为普通流,则显示如下:
根据 CSS2.1 规范第 10.6.3 部分的高度计算规则,在进行普通流中的块级非替换元素的高度计算时,浮动子元素不参与计算。
与浮动元素相邻的、创建了BFC的元素,都不能与浮动元素相互覆盖。利用该特行,可以实现多栏布局
In a block formatting context, each boxs left outer edge touches the left edge of the containing block (for right-to-left formatting, right edges touch)。
其中,grid2a.png 背景是 100px * 100px 的图片:
DIV1 是一个浮动元素,背景是50%的透明
DIV2 的 overflow:hidden;,即创建了BFC
根据 CSS 2.1 9.5 Floats 中的描述,创建了 Block Formatting Context 的元素不能与浮动元素重叠, 所以,DIV2 应该有一部分被 DIV1 覆盖。
而如果去掉’overflow:hidden’,则根据 CSS 2.1 9.5 Floats 中的描述,浮动元素会覆盖普通流中的块容器。所以,DIV2 应该有一部分会被 DIV1 覆盖。
创建了BFC的元素不会与它们的子元素发生外边距折叠
Container 是宽度为300px,含有 border 的块元素,根据标准,它不会与子元素的 margin 发生空白边折叠。
DIV1 的宽度没
您可能关注的文档
- I2012年急诊专科理论题及答案.doc
- I2012年总结和明年计划.doc
- [10.构建多元课程平台.doc
- IApp模版的功能特色介绍6模板2.doc
- [10-13临沂中考解答题分析2.doc
- IAP的含义.doc
- IARCGIS中坐标转换及地理坐标、投影坐标定义.doc
- IARMAdvancedSIMD.doc
- IAP放置和信道分配在无线局域网的优化.doc
- I2012年房地产经纪人考试经纪实务内部试题及答案.doc
- 小学科学:ESP8266智能插座电路原理与动手实践研究教学研究课题报告.docx
- 《金融开放浪潮下我国多层次监管体系构建与创新研究》教学研究课题报告.docx
- 区域教育质量监测中人工智能应用的数据质量分析与优化策略教学研究课题报告.docx
- 《金融科技监管中的数据治理与合规性要求》教学研究课题报告.docx
- 《3D打印技术在航空航天领域中的多材料制造与复合材料应用》教学研究课题报告.docx
- 《绿色金融发展中的政府职能与市场机制研究》教学研究课题报告.docx
- 《植物工厂多层立体栽培光环境调控技术对植物生长发育节律的调控机制探讨》教学研究课题报告.docx
- 销售团队年度业绩总结.docx
- 银行风险管理与金融危机防范.docx
- 银行网络攻击预警与快速响应机制.docx
最近下载
- 附件14:项目《标价分离书》.xls VIP
- 喷塑规章制度管理.doc VIP
- 2025年高考真题——物理(甘肃卷)含答案.docx VIP
- DBJD25-60-2018 甘肃省建设工程施工机械台班费用定额(含税).docx
- 考研真题 中山大学化学学院化学(B)历年考研真题汇编.docx VIP
- 2025年甘肃高考化学真题试卷含答案.docx VIP
- Colorful七彩虹 主板Intel H610H610M-D EVO V21 说明书(系统 win10 win11)用户手册.pdf
- 新九年级暑假衔接讲义 20 作文(二)描写出彩(学生版+教师版)2025八升九语文统编版.docx VIP
- 2024年甘肃高考政治试卷(真题+答案).pdf VIP
- 模板7:CSCEC8B-CM- M10303《项目商务资料档案清单》.xls VIP
文档评论(0)