文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

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

2023-06-08 07:21

关注

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

HTML:

<div class="first">    <div class="first-child1">first-child1</div>    <div class="first-child2">first-child2</div></div><div class="second">    second</div><div class="third">    third</div>

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;}

表现为:

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

产生的原因

由上面的例子可以看出,first盒子没有设置高度,由子元素撑开,但是由于子盒子设置了浮动,脱离了标准流,所以导致first盒子没有高度,表现为second和third盒子向上移动了。

可以得出产生高度塌陷的原因:

在文档流中,父元素的高度默认是被子元素撑开的,也就是子元素多高,父元素就多高。但是当为子元素设置浮动以后,子元素会完全脱离文档流,此时将会导致子元素无法撑起父元素的高度,导致父元素的高度塌陷。由于父元素的高度塌陷了,则父元素下的所有元素都会向上移动,这样将会导致页面布局混乱。

高度塌陷的解决办法:

给父元素设置固定高度。但是使用这种方式后,父元素的高度就不能根据子元素自动撑高了,可以根据自己页面的特点,如果可以固定高度,可以使用这种方式,否则,不推荐这种方式。

额外标签法,这是w3c推荐的解决方案,但是不推荐,因为html的原则是写出语义化的标签,这种方式会额外增加无意义的标签。

<div class="first">    <div class="first-child1">first-child1</div>    <div class="first-child2">first-child2</div>    <div style="clear: both;"></div></div>

父元素的overflow属性(开启元素的BFC):

.clearfix{    overflow: hidden;}

使用这种方式,属性值可以是非visible(hidden/auto/scroll)中任意,但是建议用hidden。

这种方式副作用较小,这种方式在ie6中不支持,可以外加zoom: 1;

.clearfix::after{    content: "";    display: block;    height: 0;    clear: both;    visibility: hidden;}.clearfix{    zoom: 1;}

单伪元素after清除浮动(开启元素的BFC):

.clearfix::after{    content: "";    display: block;    height: 0;    clear: both;    visibility: hidden;}.clearfix{    zoom: 1;}

这种方式现在使用比较广泛,很多大网站都是使用这种方式,副作用较小,只需要在配合处理ie6就可以了。

双伪元素清除浮动(开启元素的BFC):

.clearfix::before,.clearfix::after{    content: "";    display: block;    clear: both;}.clearfix{    zoom: 1;}

这种做法写法比较麻烦,也不推荐。

清除浮动对父元素的影响后的效果:

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

BFC相关

根据W3C的标准,在页面中元素都一个隐含的属性叫做Block Formatting Context,简称BFC,该属性可以设置打开或者关闭,默认是关闭的。

当开启元素的BFC以后,元素将会具有如下的特性:

父元素的垂直外边距不会和子元素重叠

开启BFC的元素不会被浮动元素所覆盖

开启BFC的元素可以包含浮动的子元素

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

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 资料下载
  • 历年真题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯