浅谈BFC

什么是BFC

BFC(块格式化上下文)是CSS布局中的一个重要概念,用于控制块级盒子的布局和定位。BFC是一个独立的渲染区域,其中的元素按照一定的规则进行布局,与其他区域相互隔离。

BFC具有以下特性:

  1. 内部的块级元素在垂直方向上一个接一个地放置。这意味着块级元素在垂直方向上不会重叠,而是按照其文档流的顺序一个接一个地排列。

  2. 块级盒子在水平方向上尽可能地填充其容器。当块级盒子不能一行容纳时,它会自动换行,并继续填充下一行。

  3. BFC区域内的盒子与外部的元素相互隔离。这意味着BFC内部的浮动元素不会影响到外部元素的布局,而且外部元素也不会影响到BFC内部的布局。

  4. BFC区域可以包含浮动元素。在BFC内部,浮动元素会被约束在其容器内,并且不会溢出到BFC外部。

  5. BFC区域的边界会包含其所有的子元素。这意味着如果BFC区域有浮动元素,BFC的高度会自动包裹这些浮动元素。

BFC规则:

  1. BFC内,盒子依次垂直排列。
  2. BFC内,两个盒子的垂直距离由 margin 属性决定。属于同一个BFC的两个相邻Box的margin会发生重叠【符合合并原则的margin合并后是使用大的margin】
  3. BFC内,每个盒子的左外边缘接触内部盒子的左边缘(对于从右到左的格式,右边缘接触)。即使在存在浮动的情况下也是如此。除非创建新的BFC。
  4. BFC的区域不会与float box重叠。
  5. BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。
  6. 计算BFC的高度时,浮动元素也参与计算

如何创建BFC

有几种方式可以创建BFC:

  1. 浮动元素:将元素的float属性设置为除"none"以外的值(例如"left"或"right"),该元素就会创建一个BFC。浮动元素的所有子元素都会在BFC中进行布局。
.element {float: left;
}
  1. 绝对定位元素:将元素的position属性设置为"absolute"或"fixed",该元素就会创建一个BFC。绝对定位元素的所有子元素都会在BFC中进行布局。
.element {position: absolute;
}
  1. display属性为inline-block、table-cell、table-caption等:将元素的display属性设置为"inline-block"、“table-cell”、"table-caption"等,该元素就会创建一个BFC。
.element {display: inline-block;
}
  1. overflow属性不为"visible":将元素的overflow属性设置为"auto"、“scroll"或"hidden”,该元素就会创建一个BFC。
.element {overflow: hidden;
}
  1. 根元素是BFC:整个文档的根元素(html)会自动成为BFC。

BFC的应用

BFC(块格式化上下文)在实际的布局中有很多应用。下面是一些BFC的常见运用:

  1. 清除浮动:当父元素包含浮动元素时,会导致父元素高度塌陷,无法正确包裹浮动元素。通过在父元素上创建BFC,可以解决这个问题,使父元素能够正确地包裹浮动元素。
.parent {overflow: hidden; /* 创建BFC */
}
  1. 防止边距重叠:在一些情况下,相邻的块级元素的上下边距可能会重叠。通过在其中一个元素或两个元素的父元素上创建BFC,可以防止边距重叠。
.element {overflow: hidden; /* 创建BFC */
}
  1. 实现自适应的两栏布局:通过将其中一个列的浮动属性设置为"left"或"right",并在其父元素上创建BFC,可以实现自适应的两栏布局。
.left-column {float: left;
}.parent {overflow: hidden; /* 创建BFC */
}
  1. 解决浮动元素引起的布局问题:当浮动元素位于文档流中,并影响其后续元素的布局时,可以将受影响的元素的父元素创建为BFC,以解决布局问题。
.parent {overflow: hidden; /* 创建BFC */
}
  1. 防止文字环绕浮动元素:通过在包含文字的容器元素上创建BFC,可以使文字不会环绕浮动元素,而是在其下方进行布局。
.text-container {overflow: hidden; /* 创建BFC */
}

总结

BFC在CSS布局中具有重要的作用,它可以带来以下好处和用途:

  1. 清除浮动:通过创建BFC,可以解决浮动元素导致的父元素高度塌陷的问题,使得父元素能够正确包裹浮动元素。

  2. 防止边距重叠:通过创建BFC,可以防止相邻块级元素的上下边距重叠,确保布局的可控性和一致性。

  3. 自适应布局:通过使用BFC和浮动属性,可以实现自适应的多栏布局,其中一列可以浮动,而其他列则会自动填充剩余空间。

  4. 解决浮动元素引起的布局问题:当浮动元素位于文档流中并影响其后续元素的布局时,创建BFC可以防止这种影响,确保正确的元素排列。

  5. 防止文字环绕浮动元素:通过创建BFC,可以使文本不会环绕浮动元素,而是在其下方进行布局,提高页面的可读性和一致性。

  6. 控制元素布局:BFC提供了更好的布局控制能力,使得元素的排列、定位和尺寸更加可控和灵活。

  7. 隔离作用用:创建BFC可以将其内部元素与外部元素隔离开来,避免互相影响,提高布局的可靠性和可预测性。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/4634.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

OKCC呼叫中心的坐席监控功能有什么

最近很多客户都在跟我谈他们企业的电话客服工作量都非常大,虽然客服人员在服务时应该态度谦和,但是遇到难缠的客户,客服人员总有脾气忍不住的时候,言语上会带有情绪,这些客服人员会因为服务水平欠佳让客户不满意从而产…

【EXCEL】数据录入的快捷键和正确格式

目录 0.环境 1.内容概述 2.具体内容 2.1数据录入换行换列的快捷键(标准的数据输入方式) 2.2日期的正确格式和使用(标准日期格式与长日期) 2.2.1 标准日期 2.2.2 长日期 2.2.3 显示当前日期和时间的快捷键 2.3百分比的正确…

ChatGPT助力DevOps的优势与局限

一、前言 DevOps 是一种方法论,旨在提高软件开发和 IT 运营团队的协作和效率。DevOps 涉及各种任务和流程的自动化,例如规划、编码、测试、部署、监控和故障排除。然而,其中一些任务和流程仍然有大量任务需要人工手动处理,而这会…

C#基础--委托

C#基础–委托 C#基础–委托 简单说它就是一个能把方法当参数传递的对象,而且还知道怎么调用这个方法,同时也是粒度更小的“接口”(约束了指向方法的签名) 一、什么是委托,委托的本质是什么? 跟方法有点类似…

【2023 年第三届长三角高校数学建模竞赛】B 题 长三角新能源汽车发展与双碳关系研究 18页论文、数据和代码

【2023 年第三届长三角高校数学建模竞赛】B 题 长三角新能源汽车发展与双碳关系研究 18页论文、数据和代码 1 题目 《节能与新能源汽车技术路线图 2.0》提出至 2035 年,新能源汽车市场占比超过 50%,燃料电池汽车保有量达到 100 万辆,节能汽车…

【MySQL】MySQL在Centos7环境下安装

目录 一、卸载不要的环境 1.1、查看是否有安装mysql 1.2、关闭运行的程序 1.3、卸载安装 二、配置yum 源 2.1、下载yum 源 2.2 安装yum源 2.3 查看是否已经生效 三、安装mysql服务 四、启动服务 五、登录方法 方法一(不行就下一个) 方法二(不…

动态sql语句

1.1 动态sql语句概述 Mybatis 的映射文件中&#xff0c;业务逻辑复杂时&#xff0c; SQL是动态变化的&#xff0c;此时在前面的学习中 SQL 就不能满足要求了。 参考的官方文档&#xff1a; 1.2 动态 SQL 之<if> 根据实体类的不同取值&#xff0c;使用不同的 SQL语句…

leetcode_001两数之和

1. 题目 两数之和 2. 题意 找到数组中和为给定值的两个值的坐标。 3. 题解 3.1 暴力 两重循环&#xff0c;直接列举出来。 class Solution1 { public:vector<int> twoSum(vector<int>& nums, int target) {vector<int> res;int size nums.size()…

浅谈自动化测试工具 Appium

目录 前言&#xff1a; 一、简单介绍 &#xff08;一&#xff09;测试对象 &#xff08;二&#xff09;支持平台及语言 &#xff08;三&#xff09;工作原理 &#xff08;四&#xff09;安装工具 二、环境搭建 &#xff08;一&#xff09;安装 Android SDK &#xff0…

和chatgpt学架构02-环境搭建

目录 1 安装vs code2 vs code功能介绍3 安装nodejs4 安装vue5 在vs code打开工程总结 我们在上一篇 技术选型 里咨询了chatgpt前后端的框架选择和数据库的选择。有了框架之后就需要选择合适的开发工具了&#xff0c;继续咨询一下chatgpt 我现在选型&#xff0c;前端使用vue&am…

将媒体公司资产迁移到 Amazon S3 的技术方案

随着媒体公司的发展&#xff0c;他们在仓库中积累了大量的旧磁带和未数字化的视频。这些资产可能很有价值&#xff0c;但以目前的形式很难访问和货币化。此外&#xff0c;将这些资产存储在仓库中既有风险又昂贵。 媒体企业可以通过将其资产迁移到云存储来解决这些问题&#xf…

Lua 批量修改文件夹下文件名

local s io.popen("dir C:\\Users\\lizhiyuan\\Desktop\\国家知识产权局ftp法律状态数据\\data /b/s") local filelist s:read("*a")local start_pos 0while 1 do_,end_pos,line string.find(filelist, "([^\n\r].xml)", start_pos)if not e…

Java List中通过对象属性排序,可实现多条件排序

直接上代码&#xff1a; import com.google.common.collect.Lists; import lombok.AllArgsConstructor; import lombok.Data;import java.util.Comparator; import java.util.List; import java.util.stream.Collectors;/*** List 对象属性排序*/Data AllArgsConstructor clas…

xml.etree.ElementTree

python使用 xml.etree.ElementTree包的时候&#xff0c;对xml中的空标签进行了简写&#xff0c;想恢复成正常模式怎么弄

(学习笔记-TCP连接断开)TCP四次挥手

TCP四次挥手过程 TCP断开连接是通过四次挥手实现的&#xff0c;双方都可以主动断开连接&#xff0c;断开连接后主机中的资源将被释放&#xff0c;四次挥手的过程如下&#xff1a; 客户端打算关闭连接时&#xff0c;会发送一个TCP首部FIN标志位为1的报文&#xff0c;也就是FIN报…

基础语言模型LLaMA

LLaMA包含从7B到65B参数的基础语言模型集合。Meta在数万亿个tokens上训练了模型&#xff0c;LLaMA-13B在大多数基准测试中优于GPT-3&#xff08;175B&#xff09;。 来自&#xff1a;LLaMA: Open and Efficient Foundation Language Models 目录 背景概述方法预训练数据架构Op…

LangChain + Embedding + Chromdb,关联使用ChatGLM的本地搭建训练平台教程

一.介绍 OpenAI 在国内用户注册会遇到各种阻力&#xff0c;目前可行的方法是使用本地数据集的功能实现联网搜索并给出回答&#xff0c;提炼出TXT、WORD 文档里的内容。 现在主流的技术是基于强大的第三方开源库&#xff1a;LangChain 。 文档地址&#xff1a;&#x1f99c;…

基于单片机的教室智能照明台灯控制系统的设计与实现

功能介绍 以51单片机作为主控系统&#xff1b;LCD1602液晶显示当前时间、年月日、时分秒、前教室人数&#xff1b;2路红外探头用来感应当前教室进出人数&#xff1b;按键可以设置当前时间、自动手动模式、开启和关闭教室灯光时间&#xff1b;在手动模式下&#xff0c;可以通过按…

Ip-Limit: 轻量级注解式IP限流组件(一)

author: van , ggfanwentaogmail.comIp-Limit: 轻量级注解式IP限流组件 项目简介 基于JVM缓存的轻量级、注解式IP限流组件&#xff0c;方便项目快速引用&#xff0c;满足多线程场景。 默认为滑动窗口限流器&#xff0c;内置令牌桶限流器&#xff0c;可通过注解的属性配置修改…

uni-app:单位像素rpx

rpx:响应式单位&#xff0c;长宽可以随着屏幕大小改变&#xff0c;其尺寸根据iPhone 6的标准来参考&#xff08;750rpx为占满屏幕宽&#xff0c;1334rpx为占满屏幕长。7501334rpx&#xff09; 例子&#xff1a; 现在展示型号为iPhone 12 pro的型号&#xff0c;这里750px和750…