百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程网 > 正文

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

yuyutoo 2025-04-06 00:09 5 浏览 0 评论

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

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

使用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, 可算是明白了,大家共勉。

相关推荐

国内外注塑机及电脑密码大全(常见注塑机通用密码)

一、国外注塑机(日本、德国等)东洋注塑机万能码:9422345日精注塑机密码:222|7777DAMEG注塑机密码:000000000新泻注塑机密码:241650|261450住友注塑机密码:...

并发编程实战来咯(并发编程的艺术和并发编程实战)

提到并发编程,就不得不提C++ConcurrencyinAction(SecondEdition)(《C++并发编程实战第2版》)啦!《C++并发编程实战第2版》英文原版&中文译版看到这个...

无锁队列Disruptor原理解析(无锁队列应用场景)

队列比较队列...

理解 Memory barrier(内存屏障)(内存屏障 volatile)

...

并发编程 --- CAS原子操作(cas概念、原子类实现原理)

...

无锁CAS(附无锁队列的实现)(cas是一种无锁算法)

本文所有代码对应的Github链接为:https://github.com/dongyusheng/csdn-code/tree/master/cas_queue...

Linux高性能服务器设计(linux 服务器性能)

C10K和C10M计算机领域的很多技术都是需求推动的,上世纪90年代,由于互联网的飞速发展,网络服务器无法支撑快速增长的用户规模。1999年,DanKegel提出了著名的C10问题:一台服务器上同时...

浅谈Go语言的并发控制(go语言 并发)

前言本文原创,著作权归...

Datenlord |Etcd 客户端缓存实践(etcd 数据存储)

简介和背景...

无锁编程——从CPU缓存一致性讲到内存模型

缓存是一个非常常用的工程优化手段,其核心在于提升数据访问的效率。缓存思想基于局部性原理,这个原理包括时间局部性和空间局部性两部分:...

打通 JAVA 与内核系列之 一 ReentrantLock 锁的实现原理

...

如何利用CAS技术实现无锁队列(cas会锁总线吗)

linux服务器开发相关视频解析:...

Kotlin协程之一文看懂Channel管道

概述Channel类似于Java的BlockingQueue阻塞队列,不同之处在于Channel提供了挂起的send()和receive()方法。另外,通道Channel可以...

详解C++高性能无锁队列的原理与实现

1.无锁队列原理1.1.队列操作模型...

Javascript 多线程编程的前世今生

...

取消回复欢迎 发表评论: