您现在的位置是:网站首页> 编程资料编程资料
浅谈CSS 高度塌陷问题解决CCS中的margin:top塌陷问题css高度塌陷问题的解决方案详解CSS盒子塌陷的5种解决方法关于清除浮动塌陷的几种方法总结CSS中如何解决外边距塌陷问题
2021-09-04
813人已围观
简介 这篇文章主要介绍了浅谈CSS 高度塌陷问题的相关资料,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
表现
例如:
HTML:
first-child1first-child2secondthird
CSS:
.first{ width: 300px; background-color: pink; } .first .first-child1,.first .first-child2{ float: left; width: 100px; height: 100px; } .first .first-child1{ background-color: purple; margin-right: 10px; } .first .first-child2{ background-color: red; } .second{ width: 200px; height: 150px; background-color: blue; } .third{ width: 100px; height: 150px; background-color: green; }表现为:

产生的原因
由上面的例子可以看出,first盒子没有设置高度,由子元素撑开,但是由于子盒子设置了浮动,脱离了标准流,所以导致first盒子没有高度,表现为second和third盒子向上移动了。
可以得出产生高度塌陷的原因:
在文档流中,父元素的高度默认是被子元素撑开的,也就是子元素多高,父元素就多高。但是当为子元素设置浮动以后,子元素会完全脱离文档流,此时将会导致子元素无法撑起父元素的高度,导致父元素的高度塌陷。由于父元素的高度塌陷了,则父元素下的所有元素都会向上移动,这样将会导致页面布局混乱。
高度塌陷的解决办法:
1、给父元素设置固定高度。但是使用这种方式后,父元素的高度就不能根据子元素自动撑高了,可以根据自己页面的特点,如果可以固定高度,可以使用这种方式,否则,不推荐这种方式。
2、额外标签法,这是w3c推荐的解决方案,但是不推荐,因为html的原则是写出语义化的标签,这种方式会额外增加无意义的标签。
first-child1first-child2
3、父元素的overflow属性(开启元素的BFC):
.clearfix{ overflow: hidden; }使用这种方式,属性值可以是非visible(hidden/auto/scroll)中任意,但是建议用hidden。
这种方式副作用较小,这种方式在ie6中不支持,可以外加zoom: 1;
.clearfix::after{ content: "";/*伪元素内容为空*/ display: block;/*非默认的就行,也可以是table等等*/ height: 0;/*伪元素高度为0,不影响其他元素*/ clear: both;/*清除浮动*/ visibility: hidden;/*不可见*/ } .clearfix{ zoom: 1;/*ie6元素没有BFC模式,但是这句代码会开启ie6中的hasLayout模式,只在ie中支持*/ }4、单伪元素after清除浮动(开启元素的BFC):
.clearfix::after{ content: "";/*伪元素内容为空*/ display: block;/*非默认的就行,也可以是table等等*/ height: 0;/*伪元素高度为0,不影响其他元素*/ clear: both;/*清除浮动*/ visibility: hidden;/*不可见*/ } .clearfix{ zoom: 1;/*ie6元素没有BFC模式,但是这句代码会开启ie6中的hasLayout模式,只在ie中支持*/ }这种方式现在使用比较广泛,很多大网站都是使用这种方式,副作用较小,只需要在配合处理ie6就可以了。
5、双伪元素清除浮动(开启元素的BFC):
.clearfix::before,.clearfix::after{ content: ""; display: block; clear: both; } .clearfix{ zoom: 1;/*ie6元素没有BFC模式,但是这句代码会开启ie6中的hasLayout模式,只在ie中支持*/ }这种做法写法比较麻烦,也不推荐。
清除浮动对父元素的影响后的效果:

BFC相关
根据W3C的标准,在页面中元素都一个隐含的属性叫做Block Formatting Context,简称BFC,该属性可以设置打开或者关闭,默认是关闭的。
当开启元素的BFC以后,元素将会具有如下的特性:
1.父元素的垂直外边距不会和子元素重叠
2.开启BFC的元素不会被浮动元素所覆盖
3.开启BFC的元素可以包含浮动的子元素
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- 10分钟入门CSS3 AnimationCSS3动画之利用requestAnimationFrame触发重新播放功能
- CSS实现镂空效果的示例代码CSS实现镂空遮罩效果用纯CSS实现镂空效果的示例代码CSS3中文字镂空、透明值、阴影效果设置示例小结使用CSS实现中间镂空的图片遮罩效果CSS背景色镂空技术实际应用及进阶分享css3遮罩层镂空效果的多种实现方法
- 10分钟理解CSS3 Grid布局css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 10分钟理解CSS3 FlexBox弹性布局CSS3中的弹性布局em运用入门详解 1em等于多少像素css3弹性盒子flex实现三栏布局的实现CSS3 Flex 弹性布局实例代码详解css flex 弹性布局详解CSS弹性布局FLEX,媒体查询及移动端点击事件的实现
- css实现文字居中两边横线效果的示例代码CSS Transition通过改变Height实现展开收起元素从QQtabBar看css命名规范BEM的详细介绍css实现两栏布局,左侧固定宽,右侧自适应的多种方法CSS 实现Chrome标签栏的技巧CSS实现两列布局的N种方法CSS实现隐藏搜索框功能(动画正反向序列)CSS3中Animation实现简单的手指点击动画的示例详解CSS中的特指度和层叠问题详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)关于CSS浮动与取消浮动的问题
- 详解如何在css3打包后自动追加前缀插件:autoprefixer css3中transform属性实现的4种功能详解CSS3.0(Cascading Style Sheet) 层叠级联样式表纯CSS3实现div按照顺序出入效果CSS3实现列表无限滚动/轮播效果css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效CSS3实现的侧滑菜单CSS3实现的3D隧道效果用CSS3画一个爱心css3 实现文字闪烁效果的三种方式示例代码六种css3实现的边框过渡效果
- 详解css BEM书写规范 CSS使用BEM命名规范实践CSS样式书写顺序和命名规范及注意事项值得收藏的CSS命名规范(规则)常用的CSS命名规则 好的 CSS 命名规范可以节约 Debug 时间css 命名:BEM, scoped css, css modules 与 css-in-js详解CSS规范BEM CSS和OOCSS的示例代码详解从QQtabBar看css命名规范BEM的详细介绍
- css如何绘制特殊图形的方法示例
- CSS 同级元素浮动分析小结纯css3绘制的卡通皮卡丘随着气球漂浮动画特效源码css 如何清除浮动的示例代码浅谈CSS浮动的特性CSS3 清除浮动的方法示例深入理解css布局之定位与浮动CSS清除浮动float的三种方法小结浅谈css中浮动和清除浮动带来的影响轻松搞懂CSS浮动与清除浮动图文详解
- 使用css实现圆形波浪效果图 纯CSS实现波浪移动效果的示例纯css3制作鼠标悬停波浪形状弹性下拉菜单特效源码css3实现逼真的波浪起伏动画特效源码CSS3实现的波浪闪动文字动画特效源码纯css3实现的音阶波浪loading加载动画特效源码CSS3实现文字波浪线效果示例代码纯css3实现的文字波浪动画特效源码纯CSS3实现波浪形菜单效果源码纯CSS3实现3D波浪形动画有波浪起伏的效果
