CSS中如何解决高度塌陷问题

发布时间:2021-06-11 18:23:40

来源:亿速云

阅读:58

作者:Leah

这篇文章将为大家详细讲解有关CSS中如何解决高度塌陷问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。

HTML:

first-child1
first-child2

second

third

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-child1
first-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的元素可以包含浮动的子元素

关于CSS中如何解决高度塌陷问题就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

html标签高度塌陷,CSS中如何解决高度塌陷问题相关推荐

  1. css 高度塌陷_css中父元素高度塌陷是什么意思,如何解决?(附代码)

    本篇文章给大家带来的内容是关于css中父元素高度塌陷是什么意思,如何解决?,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 首先得回答什么是父元素高度塌陷: 在文档流中,父元素的高度默 ...

  2. html 让表格在右侧显示不出来,css中怎么解决表格边框不显示的问题?

    css中怎么解决表格边框不显示的问题? html中的表格默认是不显示边框的,可以设置表格的border属性来添加边框,设置cellspacing属性为0来将边框合并,显示单一边框. css中也可以设置 ...

  3. html 语言 表格边框显示,css中怎么解决表格边框不显示的问题?

    css中怎么解决表格边框不显示的问题? html中的表格默认是不显示边框的,可以设置表格的border属性来添加边框,设置cellspacing属性为0来将边框合并,显示单一边框. css中也可以设置 ...

  4. CSS样式怎么解决高度自适应的问题?

    在css中宽度可以使用百分比布局 rem布局  flex 来实现自适应,高度确不可. 可以使用vh单位来实现高度自适应的问题,实例代码如下 100vh代表高度占满屏幕  也可以写其他数值. 注意事项要 ...

  5. 解决margin塌陷的问题_解决margin塌陷与margin合并(margin)清除浮动问题

    **1.margin塌陷** 问题:垂直方向的父子关系的盒子使用不当会产生margin塌陷.给子级设置margin-top时,他不会相对父级一起动,只有他的margin超过父级的margin时,才会生 ...

  6. HTML/CSS中,DIV高度自适应的解决方法

    在WEB开发过程中,有些需求要求DIV的高度随着浏览器窗口的改变而改变. 这里我就列举两种情况: ① 顶部为一排菜单栏,下部为内容部.其中,要求,菜单栏高度固定,内容部随着浏览器窗口大小的改变而改变, ...

  7. html css div 高度自适应,HTML/CSS中,DIV高度自适应解决办法

    获取content高度 *{color:#fff} .header{ height: 40px; width:100%; position: fixed; top:0; left:0; backgro ...

  8. css中的间隙和塌陷问题

    目录 A.间隙问题 一.自带样式产生的间隙 解决方案: 二.行内元素与行内块元素产生的间隙 产生原因: 解决方案: 三.块级元素嵌套行内元素有间隙间隙 原因:行内元素的默认垂直对齐方式是和文字基线对齐 ...

  9. css float 高度,CSS中 浮动float 高度自适应

    文章总结了浮动float 高度自适应及在这过程中碰到的一些问题方法总结. 先来看一个示例效果的对比: 这是清除浮动之前的效果.可以明显看到column1,column2,column3这三个浮动元素的 ...

最新文章

  1. git报错:Pull is not possible because you have unmerged files解决方法
  2. html模板是干嘛的,html模板有什么用
  3. cookie注入讲解
  4. mysql 转成树_Mysql树型结构2种方式及相互转换
  5. php字符串如何比较大小写,PHP字符串函数strcmp(二进制安全比较字符串,区分大小写)...
  6. VS“当前上下文中不存在名称“ViewBag”,当前上下文不存在名称“model””-已解决...
  7. 六石管理学:学习指教欢迎,刺探情报免了
  8. Linux内存管理 (3)内核内存的布局图
  9. 写的函数符号表里没有_DATEDIF函数,看看你的Excel里有没有?
  10. 【机器学习】--谱聚类从初始到应用
  11. 逸仙电商将携Galenic法国科兰黎、EVE LOM参展进博会 | 进博会倒计时
  12. Photoshop CC 2017 软件安装包+安装教程
  13. 美国高防服务器亿速云,亿速云香港高防裸金属服务器上线,更强悍的计算性能,更安全的DDoS攻击防护...
  14. 基于java web技术的班级同学录网站-计算机毕业设计
  15. 在腾讯这一年,坚守初心持续单纯 | 2021年终总结
  16. vue实现自动语音播报功能,未解决。(已用js解决20220210)
  17. 一个相当有用的利器,提高检索匹配的效率!
  18. Mac 上Grapher基础入门教程
  19. [转]60个英文阅读网站强力推荐
  20. A5000 VS 3090,谁更强?

热门文章

  1. 量子信息与量子计算_我们会看到量子计算革命吗?
  2. K3工业老单单据的相关表
  3. 王国维《人间词话》治学经验三境界
  4. 什么是web服务器?有哪些作用?
  5. 机器学习: Metric Learning (度量学习)
  6. 都23年了你还记得渐进式框架是什么意思吗
  7. Powershell操作Excel简析
  8. WebBrowser控件[Windows窗体]之介绍篇
  9. web前端高级React - React从入门到进阶之React条件渲染
  10. 人脸识别常用数据集大全(12/20更新)