您现在的位置是:网站首页> 编程资料编程资料
详解关于浮动元素float使其父元素高度塌陷的原因及解决方法css高度塌陷问题的解决方案浅谈CSS 高度塌陷问题父级元素未设置高度和宽度时高度塌陷问题的解决方法
2021-09-03
1188人已围观
简介 这篇文章主要介绍了详解关于浮动元素float使其父元素高度塌陷的原因及解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
浮动元素使其父元素高度塌陷我们经常会遇到一种情况,给一个元素设置浮动之后 float:left/right;,如果该元素的父元素有背景颜色,那么会发现父元素的背景颜色消失了;如果父元素有一个边框,那么浮动元素无法将边框撑开。


从以上两张图中可以看出添加浮动元素后,li元素按照规则横向排列,但是父元素却消失不见了。

为父元素添加一个5px的边框,在li元素添加浮动后,边框并没有被内容撑开。
在第一个示例中仿佛父元素消失了,但在第二个示例中发现其实父元素并没有消失,只是高度被计算为0。这就要回到浮动元素的特性来说明此问题“当元素设置浮动后,会自动脱离文档流”,翻译成白话就是说,元素浮动后,就不在整个文档流的管辖范围,那么它之前存在在父元素内的高度就随着浮动不复存在了,而此时父元素会默认自己里面没有任何内容(前提是未给父元素设置固定高度,如果父元素本身有固定高度,就不会出现这种情况)
解决方法:
1、给父元素也添加float。这样让父元素与子元素一起脱离文档流浮动起来,保证子元素在父元素内,这样父元素就能自适应子元素的高度,但是此方法有一弊端,一定会影响父元素之后的元素排列,甚至影响布局。
2、给父元素一个固定高度,此方法适用于子元素高度已知并且固定的情况。
3、添加一个块级元素,并给此元素设置clear:both;清除浮动。在很早之前用的就是这种解决办法,新建一个空的div,为这个div设置clear:both;这样无疑是增加了无意义的标签,一个大型页面中,这种标签太多是不好的。
4、给父元素添加 overflow:hidden;【后有详解】
5、通过伪类::after清除浮动 【后有详解】
overflow:hidden;
- 隐藏溢出,当内容超过其父元素时,可以使用该属性和值将溢出的部分裁剪掉,使页面更加美观
- 清除浮动,当子元素浮动时,给父元素添加overflow:hidden,按照它的第一个特性,应该将子元素超出的部分截掉,但是因为子元素有浮动,无法裁剪,所有只能由父元素增加高度去包裹住子元素,使得父元素拥有了高度,而这个高度是跟随子元素自适应的高度,这样就把浮动的子元素包含在父元素内了。
::after 伪类
利用伪类来清楚浮动,其效果跟创建一个空的div并设置其为clear:both;是一样的,只不过这里用伪类代替了空的div元素
我是浮动的子元素
.box { width:400px; background:#F00; } .son { float:left; } .son::after { content:""; clear:both;/*清除浮动*/ display:block;/*确保该元素是一个块级元素*/ }到此这篇关于详解关于浮动元素float使其父元素高度塌陷的原因及解决方法的文章就介绍到这了,更多相关浮动float父元素高度塌陷内容请搜索以前的文章或继续浏览下面的相关文章,希望大家以后多多支持!
相关内容
- 浅析CSS中的4种引入方式及优先级css样式引入方式及优缺点介绍关于CSS引入方式的详细见解小结详解CSS文件的三种引入方式html引入css四种引入方式示例分享Css基本概念及其引入方式介绍
- css解决浮动导致父元素高度坍塌的几种方法父元素的高度为0利用伪元素:after清除浮动可解决问题
- css样式引入方式及优缺点介绍网页引入css样式的几种方法CSS学习之一 CSS样式引入方法CSS学习之一 CSS样式的引入 IE对网页中引入CSS样式表的限制-CSS教程-网页制作-网页教学网HTML外部样式表如何引入CSS样式
- CSS适配iPhone全面屏的方法CSS网页响应式布局实现自动适配Pc/Pad/Phone设备CSS像素以及移动端不同屏幕适配问题解决postcss-pxtorem移动端适配的实现css列表滑动防止被底部遮住和适配屏幕长一点的机型处理 CSS3中媒体查询结合rem布局适配手机屏幕手机端用rem+scss做适配的详解通过CSS3的object-fit来调整图片适配尺寸的技巧简介利用css @viewport 做设备适配
- 一文了解CSS 标签显示模式详解CSS标签中的显示模式浅析css中使用border属性与display属性的方法详解css display:box 新属性浅谈CSS3中display属性的Flex布局的方法浅谈CSS的Display属性可能的值CSS display属性的table表格布局详解CSS标签模式display属性
- 详解CSS标签中的显示模式一文了解CSS 标签显示模式浅析css中使用border属性与display属性的方法详解css display:box 新属性浅谈CSS3中display属性的Flex布局的方法浅谈CSS的Display属性可能的值CSS display属性的table表格布局详解CSS标签模式display属性
- CSS盒子居中的常用的几种方法(小结)CSS 同级元素position:fixed和margin-top共同使用的问题使用CSS实现盒子水平垂直居中的方法(8种)css 利用 position + margin 实现固定盒子横向纵向居中的方法
- 使用css实现特殊标志或图形使用CSS的clip-path属性实现不规则图形的显示css如何绘制特殊图形的方法示例详解常用css样式(布局)详解CSS3中常用的样式【基本文本和字体样式】编程式处理Css样式的示例代码使用CSS伪元素控制连续几个元素的样式方法纯CSS3 gradient属性制作36种漂亮的html网页渐变按钮样式css样式常见图形效果展示的实例代码
- CSS样式的分类介绍(基础知识)CSS教程:scrollbar的属性知识及样式分类介绍
- svg+css 或者js制作打钩的动画效果CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
