博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
前端学习 -- Css -- 高度坍塌问题的产生以及解决
阅读量:6983 次
发布时间:2019-06-27

本文共 1323 字,大约阅读时间需要 4 分钟。

在文档流中,父元素的高度默认是被子元素撑开的,也就是子元素多高,父元素就多高。

但是当为子元素设置浮动以后,子元素会完全脱离文档流,此时将会导致子元素无法撑起父元素的高度,导致父元素的高度塌陷。
由于父元素的高度塌陷了,则父元素下的所有元素都会向上移动,这样将会导致页面布局混乱。
所以在开发中一定要避免出现高度塌陷的问题,我们可以将父元素的高度写死,以避免塌陷的问题出现,但是一旦高度写死,父元素的高度将不能自动适应子元素的高度,所以这种方案是不推荐使用的。

解决高度坍塌措施:

根据W3C的标准,在页面中元素都一个隐含的属性叫做Block Formatting Context

简称BFC,该属性可以设置打开或者关闭,默认是关闭的。
当开启元素的BFC以后,元素将会具有如下的特性:
  1.父元素的垂直外边距不会和子元素重叠
  2.开启BFC的元素不会被浮动元素所覆盖
  3.开启BFC的元素可以包含浮动的子元素
如何开启元素的BFC
  1.设置元素浮动(不推荐)
    - 使用这种方式开启,虽然可以撑开父元素,但是会导致父元素的宽度丢失,而且使用这种方式也会导致下边的元素上移,不能解决问题
  2.设置元素绝对定位(不推荐)
  3.设置元素为inline-block(不推荐)
  - 可以解决问题,但是会导致宽度丢失,不推荐使用这种方式
  4.将元素的overflow设置为一个非visible的值(aotu hidden)
推荐方式:将overflow设置为hidden是副作用最小的开启BFC的方式。
overflow: hidden;
但是在IE6及以下的浏览器中并不支持BFC,所以使用这种方式不能兼容IE6。
在IE6中虽然没有BFC,但是具有另一个隐含的属性叫做hasLayout,该属性的作用和BFC类似,所在IE6浏览器可以通过开hasLayout来解决该问题开启方式很多,我们直接使用一种副作用最小的:
直接将元素的zoom设置为1即可。

zoom表示放大的意思,后边跟着一个数值,写几就将元素放大几倍
zoom:1表示不放大元素,但是通过该样式可以开启hasLayout
zoom这个样式,只在IE中支持,其他浏览器都不支持。

高度坍塌的情况:

            

高度坍塌的效果:

通过zoom和overflow解决问题:

            

看下效果:

问题解决

 github上传了代码:

https://github.com/soyoungboy/htmlCssStudy

见lesson22和lesson,在浏览器里面运行下看看

 

转载地址:http://iytpl.baihongyu.com/

你可能感兴趣的文章
pcDuino入门心得+HDMI声音+蓝牙功放
查看>>
面向对象2
查看>>
c++测试题2016-6-2
查看>>
Nginx与Serssion一致性问题
查看>>
社会化工程攻击针对目标不再仅限最终用户
查看>>
Hadoop源码分析HDFS ClientProtocol——getBlockLocations
查看>>
AndroidWidget实践 --- EverydayTips开发(6)
查看>>
mysql 随机查询数据
查看>>
CodeIgniter学习笔记一
查看>>
workspace-project-target关系与解耦工程结构总结
查看>>
EhCache的配置
查看>>
Linux 设置时区
查看>>
在maven中引用github上的资源
查看>>
4、Angular JS 学习笔记 – 创建自定义指令 [翻译中]
查看>>
Flex手机开发-退出应用程序
查看>>
常用的7大排序算法汇总
查看>>
数字转化成时分秒(二)
查看>>
Golang通过syscall调用win32的Api
查看>>
阿里云Redis (安装包安装篇)
查看>>
Spring Bean的装配(非XML文件方式)
查看>>