首先,我们要思考一个问题:为什么要清除浮动呢?在我做小demo的时候,碰到一个问题,当子元素浮动的时候,父元素的背景颜色消失了?可以说,以当时我的菜鸟水平,是不知道为什么父元素的背景颜色为什么会不见,我明明设置了背景颜色的,难道颜色格式不对?或者是浏览器不兼容,是个css hack????????所有的猜测都指向了背景颜色,都是背景颜色的错。为什么要清除浮动?在坑中不断挣扎的我,得到了答案,不是背景颜色的错。而是它的子元素。当子元素浮动的时候会导致父元素的height变为0,这是为什么呢? 原因是父元素没有设置高度,原本的高度,是由子元素撑起来的。当子元素浮动的时候,子元素是脱离文档流的,而父元素还是文档流里,这个时候,父元素的content没有东西,所以父元素的height就变为原本没有设置的高度(为0)。如果父元素的content中有非float的元素,则以这些元素的最高的高度撑起父元素的高度。如图所示:HTML代码 在没有浮动时的情况: HTML代码 //此时大图片左浮动,及下图的效果 在浮动时的情况:(大图片float:left;小图片不变) 可以从上面的分析得出。子元素浮动,会导致父元素出现“高度塌陷”。如何清除浮动?清除浮动的方式有很多种,目前看到有八种左右的清除浮动的方式。但真正用到项目里,最常见的方式有两种: 1.添加伪类:after; 2.触发BFC; 1.添加伪类:after 给父元素添加一个类clearfix,并给这个类设置伪类:after。 Document .clearfix:after { content: " "; display: block; clear: both; } .a { float: left; } 看吧!这就是第一种清除浮动的方法。也是广受欢迎的一种清除浮动个方式。 2.触发BFC1)什么是BFC? BFC(Block Formatting Context)是Web页面中盒模型布局的CSS渲染模式。它的定位体系属于常规文档流。摘自W3C: 浮动,绝对定位元素,inline-blocks, table-cells, table-captions,和overflow的值不为visible的元素,(除了这个值已经被传到了视口的时候)将创建一个新的块级格式化上下文。 上面的引述几乎总结了一个BFC是怎样形成的。但是让我们以另一种方式来重新定义以便能更好的去理解。一个BFC是一个HTML盒子并且至少满足下列条件中的任何一个:float的值不为noneposition的值不为static或者relativedisplay的值为 table-cell, table-caption, inline-block, flex, 或者 inline-flex中的其中一个overflow的值不为visible2) 如何用BFC清除浮动 粗暴的总结就是让浮动块包含在同一个BFC中加同时(也可以理解为包含块加属性overflow:hidden)。 Document .container { overflow: hidden; } .a { float: left; } 有利也有弊,下面简单指出BFC的缺点: - display:table可能会产生一些问题 - overflow:scroll可能会显示不必要的滚动条 - float:left将会把元素置于容器的左边,其他元素环绕着它 - overflow:hidden将会剪切掉溢出的元素
0
0
相关文章
css z index 不生效怎么办_层级失效常见原因总结
css grid布局和浮动元素混合时错位怎么办_分离布局避免冲突
css响应式布局下导航菜单无法折叠怎么办_使用media查询和flex-direction切换
CSS布局弹窗无法居中怎么办_使用flex与min-height实现真正垂直居中
css表单校验失败样式怎么写_通过css:invalid伪类提示错误
本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
热门AI工具
相关专题
css是层叠样式表,用来表现HTML或XML等文件样式的计算机语言,不仅可以静态地修饰网页,还可以配合各种脚本语言动态地对网页各元素进行格式化。php中文网还为大家带来html的相关下载资源、相关课程以及相关文章等内容,供大家免费下载使用。
503
2023.06.15
css居中:1、通过“margin: 0 auto; text-align: center”实现水平居中;2、通过“display:flex”实现水平居中;3、通过“display:table-cell”和“margin-left”实现居中。本专题为大家提供css居中的相关的文章、下载、课程内容,供大家免费下载体验。
261
2023.07.27
cssCSS是层叠样式表(Cascading Style Sheets)的缩写。它是一种用于描述网页或应用程序外观和样式的标记语言。CSS可以控制网页的字体、颜色、布局、大小、背景、边框等方面,使得网页的外观更加美观和易于阅读。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。
735
2023.07.28
在CSS中,当文本内容超出容器的宽度或高度时,可以使用省略号来表示被隐藏的文本内容。本专题为大家提供css超出显示...的相关文章,相关教程,供大家免费体验。
535
2023.08.01
CSS中,字体颜色可以通过属性color来设置,用于控制文本的前景色,字体颜色在网页设计中起到很重要的作用,具有以下表现作用:1、提升可读性;2、强调重点信息;3、营造氛围和美感;4、用于呈现品牌标识或与品牌形象相符的风格。
751
2023.08.10
CSS是层叠样式表(Cascading Style Sheets)的缩写,是一种用于描述网页(或其他基于 XML 的文档)样式与布局的标记语言,CSS的作用和意义如下:1、分离样式和内容;2、页面加载速度优化;3、实现响应式设计;4、确保整个网站的风格和样式保持统一。
595
2023.08.10
CSS(层叠样式表)可以用于设置文字颜色,这样做有以下好处和优势:1、增加网页的可视化效果;2、突出显示某些重要的信息或关键字;3、增强品牌识别度;4、提高网页的可访问性;5、引起不同的情感共鸣。
387
2023.08.22
热门下载
相关下载
精品课程
最新文章


