css的布局(BFC)

news2024/11/24 11:38:46

一、css中常规的定位方案

        1、普通流

元素按照其在HTML中的先后位置自上而下布局。

        行内元素水平排列,当行被占满后换行;块级元素则会被渲染为完整的一行。

        所有元素默认都是普通流定位。 

        

        2、浮动

元素首先按照普通流的位置出现, 然后根据浮动的方向尽可能的向左或向右偏移。

        浮动元素不占用普通流元素的位置。 

        浮动后的元素具备行内块的特点;顶对齐;脱标。

        

        3、绝对定位 

绝对定位的元素与浮动类似,都是脱标元素,不占位。 

        

二、常规布局下的问题(不是bug)

        1、外边距重叠

.box{
  width: 100px;
  height: 100px;
  background: pink;
}
.box1 {
  margin-bottom: 20px;
}
.box2 {
  margin-top: 10px;
}

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

 

        2、浮动的元素可以使父盒子高度塌陷

.box1{
  border: 2px solid lightcoral;
}
.box2 {
  width: 100px;
  height: 100px;
  background: lightblue;
  float: left;
}

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

 

        3、浮动元素会覆盖其他元素

.box1 {
  width: 100px;
  height: 100px;
  background: lightblue;
  float: left;
}
.box2{
  width: 200px;
  height: 200px;
  background: lightcoral;
}

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

        4、父子盒子嵌套外盒子塌陷

.box1{
  width: 200px;
  height: 200px;
  background: lightblue;
}
.box2 {
  width: 100px;
  height: 100px;
  background: lightpink;
  margin-top: 20px;
}

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

三、BFC详解 

        1、概念

        BFC--Block_formating_context,块级格式化上下文

        2、解释

         BFC是一个独立的区域,有自己的渲染规则。使用了BFC相当于加了容器隔离,使BFC内部的元素与外部元素在布局上互不影响通俗一点来讲,可以把 BFC 理解为一个封闭的大箱子,箱子内部的元素无论如何翻江倒海,都不会影响到外部。

        3、特性

                a、每个BFC区域只包含其子盒子,不包含其孙子盒子
                b、每个BFC区域相互独立,互不影响

        4、渲染规则

                a、BFC的区域不会与 float的元素区域重叠
                b、计算BFC的高度时,浮动子元素也参与计算
                c、BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素,反之亦然

                d、 BFC的区域会计算盒子到父盒子margin-top的距离

        5、BFC的作用(解决问题)

                a、外边距重叠
                b、浮动的元素可以使父盒子高度塌陷
                c、浮动元素 覆盖其他元素
                d、父子盒子嵌套外盒子塌陷

        6、如何让一个常规盒子变为BFC盒子

                 只要元素满足下面任一条件即可触发 BFC 特性:

                        a、html根元素
                        b、浮动元素:float除none以外的值
                        c、绝对定位元素:position(absolute、fixed)
                        d、display为inline-block、table-cells、flex 、flow-root
                        e、overflow除了visible 以外的值(hidden、auto、scroll)
                        常用:overflow:hidden,display: flow-root因为他没有副作用

        7、BFC解决外边距重叠问题

.box{
  width: 100px;
  height: 100px;
  background: pink;
}
.box1 {
  margin-bottom: 20px;
}
.box2 {
  margin-top: 10px;
}
.container {
  overflow: hidden;
}

<div class="container">
  <div class="box box1"></div>
</div>
<div class="container">
  <div class="box box2"></div>
</div>

 

        8、BFC解决浮动的元素可以使父盒子高度塌陷

.box1{
  border: 2px solid lightcoral;
  display: flow-root;
}
.box2 {
  width: 100px;
  height: 100px;
  background: lightblue;
  float: left;
}

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

 

        9、BFC解决浮动元素会覆盖其他元素 

.box1 {
  width: 100px;
  height: 100px;
  background: lightblue;
  float: left;
}
.box2{
  width: 200px;
  height: 200px;
  background: lightcoral;
  display: flow-root;
}

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

        10、BFC解决父子盒子嵌套外盒子塌陷

.box1{
  width: 200px;
  height: 200px;
  background: lightblue;
  display: flow-root;
}
.box2 {
  width: 100px;
  height: 100px;
  background: lightpink;
  margin-top: 20px;
}

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

 

 

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

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

相关文章

车载电子电器架构 —— 网络拓扑开发概述

车载电子电器架构 —— 网络拓扑开发概述 我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 屏蔽力是信息过载时代一个人的特殊竞争力,任何消耗你的人和事,多看一眼都是你的不对。非必要不费力证明…

【Java从入门到精通】Java变量类型

Java 变量类型 在 Java 语言中&#xff0c;所有的变量在使用前必须声明。 声明变量的基本格式如下&#xff1a; type identifier [ value][, identifier [ value] ...] ; 格式说明&#xff1a; type -- 数据类型。identifier -- 是变量名&#xff0c;可以使用逗号 , 隔开…

Github 2024-02-08 开源项目日报 Top9

根据Github Trendings的统计&#xff0c;今日(2024-02-08统计)共有9个项目上榜。根据开发语言中项目的数量&#xff0c;汇总情况如下&#xff1a; 开发语言项目数量Ruby项目1HTML项目1Python项目1Scala项目1PLpgSQL项目1Rust项目1NASL项目1C项目1TypeScript项目1非开发语言项目…

AI:126-基于深度学习的人体情绪识别与分析

🚀点击这里跳转到本专栏,可查阅专栏顶置最新的指南宝典~ 🎉🎊🎉 你的技术旅程将在这里启航! 从基础到实践,深入学习。无论你是初学者还是经验丰富的老手,对于本专栏案例和项目实践都有参考学习意义。 ✨✨✨ 每一个案例都附带有在本地跑过的关键代码,详细讲解供…

Java实现教学资源共享平台 JAVA+Vue+SpringBoot+MySQL

目录 一、摘要1.1 项目介绍1.2 项目录屏 二、功能模块2.1 数据中心模块2.2 课程档案模块2.3 课程资源模块2.4 课程作业模块2.5 课程评价模块 三、系统设计3.1 用例设计3.2 类图设计3.3 数据库设计3.3.1 课程档案表3.3.2 课程资源表3.3.3 课程作业表3.3.4 课程评价表 四、系统展…

leetcode链表相关题目

文章目录 1.移除链表元素方法1&#xff1a;方法2 2.合并两个有序链表3.链表的中间节点方法1方法2 4.反转单链表方法1方法2 5.分割链表6.链表中的倒数第k个节点方法1&#xff1a;方法2: 7.环形链表的约瑟夫问题8.链表的回文结构9.相交链表方法1方法2&#xff1a; 10.环形链表11.…

JMM(Java内存模型)

Java内存模型&#xff08;Java Memory Model&#xff0c;简称JMM&#xff09;是Java语言规范中定义的一个抽象概念&#xff0c;它描述了程序中各个变量&#xff08;包括实例字段、静态字段和构成数组对象的元素&#xff09;在并发环境下的访问规则和一致性保证。JMM的主要目标是…

2024年低代码平台概览:国内主流平台一览

低代码开发是一项革命性的技术&#xff0c;主要目的是尽量避免程序研发的复杂性&#xff0c;让外行开发者也能加入到应用程序的搭建中。低代码平台的核心概念和构成部分通常包括用户界面和拖拽设计、预构件和模块、自动化工作内容与数据库集成和扩展应用&#xff0c;应用低代码…

73. 矩阵置零(Java)

目录 题目描述&#xff1a;输入&#xff1a;输出&#xff1a;代码实现&#xff1a; 题目描述&#xff1a; 给定一个 m x n 的矩阵&#xff0c;如果一个元素为 0 &#xff0c;则将其所在行和列的所有元素都设为 0 。请使用 原地 算法。 输入&#xff1a; matrix [[1,1,1],[1,0,…

C语言学习记录

牛牛的第二个整数_牛客题霸_牛客网 (nowcoder.com) 注意输入的格式&#xff0c;%d空格%d空格%d

《统计学简易速速上手小册》第7章:时间序列分析(2024 最新版)

文章目录 7.1 时间序列数据的特点7.1.1 基础知识7.1.2 主要案例&#xff1a;股票市场分析7.1.3 拓展案例 1&#xff1a;电商销售预测7.1.4 拓展案例 2&#xff1a;能源消耗趋势分析 7.2 时间序列模型7.2.1 基础知识7.2.2 主要案例&#xff1a;股价预测7.2.3 拓展案例 1&#xf…

第72讲后台管理Container布局实现

新建layout目录 登录成功后&#xff0c;跳转layout布局容器页面 login页面&#xff1a; 导入router import router from "/router";登录成功&#xff0c;跳转后台管理页面 选用布局容器&#xff1a; <template><div class"common-layout">…

【Linux】基础命令 第二篇

目录 echo 输出重定向:(本质都是写入) 输入重定向cat more 指令 && less指令 head && tail && 管道初步使用 grep&#xff1a;行文本过滤工具&#xff08;文本按行搜索&#xff09; date&#xff1a;获取时间 date 命令用于 显示 或 设置系统的…

HCIA-HarmonyOS设备开发认证V2.0-3.2.轻量系统内核基础-中断管理

目录 一、中断基础概念二、中断管理使用说明三、中断管理模块接口四、代码分析&#xff08;待续...&#xff09; 一、中断基础概念 在程序运行过程中&#xff0c;出现需要由 CPU 立即处理的事务时&#xff0c;CPU 暂时中止当前程序的执行转而处理这个事务&#xff0c;这个过程…

【数学建模】【2024年】【第40届】【MCM/ICM】【F题 减少非法野生动物贸易】【解题思路】

一、题目 &#xff08;一&#xff09; 赛题原文 2024 ICM Problem F: Reducing Illegal Wildlife Trade Illegal wildlife trade negatively impacts our environment and threatens global biodiversity. It is estimated to involve up to 26.5 billion US dollars per y…

C#,卢卡斯数(Lucas Number)的算法与源代码

1 卢卡斯数&#xff08;Lucas Number&#xff09; 卢卡斯数&#xff08;Lucas Number&#xff09;是一个以数学家爱德华卢卡斯&#xff08;Edward Lucas&#xff09;命名的整数序列。爱德华卢卡斯既研究了这个数列&#xff0c;也研究了有密切关系的斐波那契数&#xff08;两个…

一些AI工具的初探和使用

0. 前言 目前我自己对于AI的应用还不成熟&#xff0c;先记录一下常用的AI工具&#xff0c;后续再进行探索。 目前AI发展的速度已经超出想象了。可能最开始我对ai的应用 还停留在回答问题以及自己领域的可以生成cursor,还有阿里家通义灵码。都还是程序员的范畴。 然后对于文字…

黑马程序员——html css基础——day10day11day12——小兔鲜儿

目录&#xff1a; 底部盒子制作 底部服务模块制作底部帮助模块底部版权模块banner-轮播图 HTML结构CSS样式banner图片模块 htmlcssbanner小圆点制作 htmlcssbanner-侧导航 HTML结构CSS样式新鲜好物-hd HTML结构CSS样式新鲜好物-bd HTML结构CSS样式溢出文字显示省略号人气推荐 …

专业课145+总分410+华南理工大学811信号与系统考研经验华工电子信息与通信,真题,大纲,参考书。

大家好&#xff0c;今年考研顺利上岸华南理工大学&#xff0c;专业课811信号与系统145&#xff08;只差一点满分&#xff0c;有点遗憾&#xff0c;专业我跟着Jenny老师复习投入时间和精力和数学差不多&#xff0c;华工专业课难度中等&#xff0c;是一个总分提高很好的突破口&am…

备战蓝桥杯---数学基础2

学了常见的筛法&#xff0c;让我们看个题&#xff1a; 首先&#xff0c;我们知道欧拉筛复杂度为nlognlogn,这题可以承受&#xff0c;但是空间上存不了&#xff0c;而如果我们枚举1--n^1/2&#xff0c;复杂度不允许。 其实在枚举的方法中&#xff0c;我们只需找出有无在【2&…