2022-01-05 overflow:hidden的作用有哪些?它解决高度塌陷的原理是什么?

一.总结
1.overflow:hidden可以用来设置溢出隐藏,清除浮动(解决高度塌陷),解决外边距坍塌
2.它解决高度塌陷的原理是设置overflow:hidden的元素会触发BFC,BFC的原理是会让设置浮动的子元素也计算高度,缺点是会影响定位在元素外面的元素
二.代码验证
1.溢出隐藏
  <style>
    #one{
      width: 100px;
      height: 50px;
      background-color: aliceblue;
      overflow:hidden;
    }
  </style>
</head>
<body>
  <div id="one">床前明月光,疑是地上霜,举头望明月,低头思故乡</div>
</body>

效果:略

2.解决高度坍塌
  <style>
    #two{
      width: 300px;
      background-color: aliceblue;
      overflow:hidden;
    }
    .child{
      width: 100px;
      height: 100px;
    }
    .left{
      background-color: blue;
      float: left;
    }
    .right{
      background: red;
      float:right;
    }
  </style>
</head>
<body>
  <div id="two">
      <div class="child left"></div>
      <div class="child right"></div>
  </div>
</body>

效果:略

3.解决外边距塌陷:子元素设置margin-top导致父元素跟着下拉
  <style>
    #three{
      width: 300px;
      height: 300px;
      background-color: pink;
      overflow:hidden;
    }
    .child{
      width: 100px;
      height: 100px;
      background: blue;
      margin-top:20px;
    }
  </style>
</head>
<body>
  <div id="three">
      <div class="child"></div>
  </div>
</body>

效果:略

三.延伸内容:高度塌陷都有哪些解决方法?
1.父元素设置固定高度
2.子元素后面创建一个空盒子
3.子元素后面设置伪元素
4.overflow:hidden
四.延伸内容:overflow:hidden为什么可以解决高度塌陷?BFC和它的原理是什么?

BFC(Block Formatting Context),块级格式化上下文,
它规定了内部的块级元素的布局方式,默认情况下只有根元素(即body)一个块级上下文。

1、BFC布局规则

内部的块级元素会在垂直方向,一个接一个地放置;
块级元素垂直方向的距离由margin决定。
属于同一个BFC的两个相邻的块级元素会发生margin合并,
不属于同一个BFC的两个相邻的块级元素不会发生margin合并;

BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素;外面的元素也不会影响到容器里面的子元素;
计算BFC的高度时,浮动元素也参与计算。
详解:

为什么"overflow:hidden"能清除浮动的影响。
我们经常会在父元素里设置某个子元素浮动。
浮动后,子元素脱离了文档流,使得父元素无法包住这个浮动的子元素。
我们通常在父元素上设置一个clearfix的伪元素来清除浮动;
同样,我们可以利用BFC可以包含浮动这一特性来清除浮动

在“BFC布局规则”中提到:计算BFC的高度时,浮动元素也参与计算。
因此,父元素在计算其高度时,加入了浮动元素的高度,
“顺便”达成了清除浮动的目标,所以父元素就包裹住了子元素。
2、创建一个BFC

首先我们要知道怎样创建BFC。一个BFC可以被显式触发,只需满足以下条件之一:

  • float的值不为none;
  • overflow的值不为visible;
  • position的值为fixed / absolute;
  • display的值为table-cell / table-caption / inline-block / flex / inline-flex。
3.BFC的另一应用:消除margin合并

对于发生margin合并的元素,我们怎样消除margin合并?

对于父子元素,我们可以通过设置padding、border、inline content、height、min-height、max-height等属性来消除;
但是相邻的兄弟元素之间必出现margin合并,这时如果想要消除margin合并,又该怎么办

我们首先要搞清楚为什么会发生margin合并。这些元素(包括兄弟、父子元素等)之间之所以会发生margin合并,
是因为它们属于同一个BFC。
所以,只要让它们不属于同一个BFC就可以了

关键代码:

#top{
	......
	margin-bottom:30px;
	overflow:hidden;
}
#bottom{
	margin-top:20px;
}

效果:两个相邻元素的上下间距从30px变成50px

### IntelliJ IDEA 2025 安装教程 #### 准备工作 为了确保顺利安装 IntelliJ IDEA 2025 版本,在开始之前需确认操作系统环境已准备好。对于 Windows 用户来说,建议先检查系统是否满足最低硬件需求以及是否有足够的磁盘空间[^1]。 #### 下载 IntelliJ IDEA 2025 访问官方网站 [IntelliJ IDEA – the Leading Java and Kotlin IDE](https://www.jetbrains.com/idea/) ,找到对应于 2025 年发布的最新版链接并点击下载适合当前操作系统的安装包文件。通常页面会自动检测用户的平台类型提供相应的选项;如果未自动识别,则手动选择合适的版本进行下载[^2]。 #### 执行安装程序 双击刚刚下载好的 `.exe` 文件启动安装向导。按照提示逐步完成设置过程,期间可以选择自定义组件或接受默认推荐配置。值得注意的是,在此阶段还可以指定产品密钥以激活专业特性,不过社区版无需额外授权即可免费使用全部基础功能。 #### 配置 JDK 环境(可选) 虽然不是强制性的前置条件,但如果计划从事 Java 开发项目的话,提前安装好适当版本的 JDK 是很有必要的。可以通过官方渠道获取最新的 JDK 发行版,并将其路径添加到系统的环境变量中以便后续集成开发环境中能够正确调用编译工具链。 #### 启动与初始化 成功安装完毕之后,通过桌面快捷方式打开应用程序。首次运行时可能会经历一段短暂的数据加载时间用于构建索引库和其他准备工作。此时可以根据个人喜好调整界面布局、主题样式等外观属性,同时也可以探索插件市场寻找有助于提高工作效率的各种扩展模块。 ```bash # 如果遇到任何问题可以尝试重启IDE解决问题 ./idea.sh restart ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端OnTheRun

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值