关于元素高度不会被内部浮动元素撑开的问题

本文部分内容引用自https://www.zhihu.com/question/30938856

在写页面的时候,碰到了一个问题,外部标签的height属性值明明为auto,但其高度却说什么都不考虑其中一个子标签的高度,如图:

外部标签的高度只是考虑到了input控件,却并未考虑文本处的标签内容。

元素高度不会被内部浮动元素撑开的原因

经过各种翻查资料,终于知道,一切问题都来源于float。我将文本处的标签设置为了浮动,而浮动元素是脱离了文档流的,此时其他元素都视其为不存在,外部标签当然不会再去考虑他的存在了,与其相同的,还有当position值为relative时的标签,该类标签由于脱离了文档流,同样不会被外部标签作为考虑元素,来算其本身的高度。

解决该问题的方法

就是给父标签设置一个属性:overflow。即添加overflow:hidden。果然撑起了外部标签的高度,如图

该方法的原理

为什么这样就会解决了这个状况呢,我又百思不得其解了,又是一顿查资料,最后这个解决方案的原理找到了,原来,当我们设置了overflow:hidden时,会触发BFC,BFC的意思是,我这个元素里面的子孙元素,不会影响外部元素的布局。 而浮动本身会造成行内宽度的压缩,进而可以影响布局。所以这违反了其自己设置的规则啊,子孙元素还是会影响外部元素布局啊,于是,说话算话的BFC就反其道而行,不让浮动元素造成宽度的压缩,将其撑起来,由此,实现了我们的目的,让float元素成功的撑起了外部标签的高度。


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值