当前位置: 萬仟网 > IT编程>网页制作>CSS > CSS-高度塌陷问题

CSS-高度塌陷问题

2018年12月25日 04:37  | 萬仟网IT编程  | 我要评论

目录

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

表现为:

在这里插入图片描述

产生的原因

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

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

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

高度塌陷的解决办法:

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

  2. 额外标签法,这是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>
  3. 父元素的overflow属性(开启元素的bfc):

    .clearfix{
        overflow: hidden;
    }

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

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

    .clearfix{
        overflow: hidden;
        zoom: 1;/*针对ie6*/
    }
  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的元素可以包含浮动的子元素

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

  • Web前端——Html常用标签及属性

    html 常用的标题等标签就不记录了,只记录一下比较少见的标签以及属性 表格 table td 单元格 tr 表的行 th 表头 td或th可以下面... [阅读全文]
  • 如何成为一名优秀的web前端工程师

    如何成为一名优秀的web前端工程师

    何为:前端工程师? 前端工程师,也叫Web前端开发工程师。他是随着web发展,细分出来的行业。 Web前端开发技术主要包括三个要素:HTML、CSS... [阅读全文]
  • &lt;img&gt;标签--基础标签

    [2019.06.22 学习笔记1] 1.<img>图片标签,自闭合标签 2.必要属性src,src="图片地址" ... [阅读全文]
  • DTD文档模型是什么

    [2019.06.22 学习笔记3] 1.DTD文档模型是DOCTYPE文档声明,是Doucument Type Definition的英文缩写,是... [阅读全文]
  • Web前端——css

    Web前端——css

    css 推荐的样式编写顺序: 1. Positioning:定位 2. Box model:盒子模型、大小等 3. Typographic:文字系列... [阅读全文]
  • 博客园美化主题需要这几步

    博客园美化主题需要这几步

    博客园美化主题需要这几步 本人现用的这套博皮是根据bndong的博客进行修改的,且配置需要时间,有兴趣可以直接访问bndong博客,查看置顶博文进行... [阅读全文]
  • iconfont采坑

    iconfont采坑

    1. iconfont采坑 1.1. 前言 1. 使用iconfont过程中踩过坑特此记录 2. 不知道iconfont的这里也简单介绍一笔,阿里开... [阅读全文]
  • css网页布局模板

    效果如图: 菜鸟教程(runoob.com) 我的网页 重置浏览器大小查看效果。 我的网页 重置浏览器大小查看效果。 链接 链接 链接 链接 文章标... [阅读全文]
  • css基础4

    今天是2019年6月21日,周五了。在这里写上一篇随笔,主要内容是css基础中的一些细节部分,话不多说,直接上! 一、背景渐变: backgroun... [阅读全文]
  • CSS filter 属性

    CSS filter 属性

    filter 将模糊或者颜色偏移等图像效果用于元素,通常用于调整图像,背景和边框的渲染 css 标准中已内置一些预定义效果的函数,也可通过url使用... [阅读全文]

◎已有 0 人评论

Copyright © 2019  萬仟网 保留所有权利. 粤ICP备17035492号-1
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com