前端面试-清浮动还能问的这么刁钻么?

前端面试题万万千,每每感觉准备的差不多的时候总会出现奇怪的题型,大家还得提升自己,互相学习呀。

在网页布局中,浮动元素脱离了文档流,可能会导致父元素高度塌陷等问题,所以出现了清理浮动的需求。

使用clear属性

在元素末尾添加一个空的div,设置属性 clear: both;

这个属性的作用就是清除元素左右两边的浮动。

使用overflow属性

父元素添加 overflow:hidden;

伪元素清除法(推荐方案)

父元素添加上面的class,这个方法不同添加额外的空元素。

父元素浮动法

display: flow-root(最新方案)

这个方法比较新颖,答出来会让面试官感觉你是持续跟进技术一线的。

看到这里大家可能会觉得这不是众所周知的东西么,冷不防的居然会问:

overflow: hidden 为什么能实现清理浮动的效果?

  • 什么是块级格式化上下文:BFC 是 Web 页面中盒模型布局的 CSS 渲染模式,它是一个独立的渲染区域,规定了内部元素如何布局,以及与外部元素的相互关系和作用。
  • BFC 的特点内部的盒子会在垂直方向上一个接一个地排列。BFC 区域不会与浮动元素重叠。BFC 是一个独立的容器,内部元素的布局不会影响到外面的元素,反之亦然。计算 BFC 的高度时,会包括浮动元素的高度。
  • 清除浮动的原理:当一个元素设置了overflow:hidden后,它就创建了一个 BFC。根据 BFC 的特点,其内部的浮动元素会参与 BFC 的高度计算,从而使包含浮动元素的父元素能够正确地计算出高度,避免了因浮动导致的父元素高度塌陷问题,也就达到了清除浮动的效果。

以前不太理解的BFC, 可算是明白了,大家共勉。

原文链接:,转发请注明来源!