html中清除浮动after,DIV+CSS 清除浮动常用方法大全

本文总结了DIV+CSS布局中清除浮动的常见方法,包括:1) 使用clear:both; 2) 设置父元素overflow:hidden; 3) 利用:after伪类和zoom属性;4) 使用clearfix类。每种方法的适用场景和效果均有详细阐述,旨在帮助开发者更好地理解和应用这些技巧。
摘要由CSDN通过智能技术生成

DIV+CSS 清除浮动是页面布局中常见的问题,相信各位高手也都有自己的方法,今天在这里对常见的几种方法进行总结(PS:谈不上是原创,这里是我自己做的归纳总结,也是我自己内化的过程),希望对您能够有所帮助。

DIV+CSS 浮动效果是指,父元素在未定义高的情况下,由于子元素全部浮动脱离文本流,而造成父元素高的塌陷(PS:正常情况下,父元素的高是由子元素撑起来);或者因为部分子元素的而浮动,脱离文本流而造成其他元素的布局错乱的情况。

DIV+CSS 清除浮动 常见的方法如下:

1、给未加浮动的子元素的CSS添加 clear: both;若子元素都有浮动时,可以新增加一个空的子元素,并且给其的CSS添加 clear: both;这样可以利用清除左右浮动的子元素重新撑起父元素的高,从而达到清除浮动的效果。代码及效果如下:

.fl{float:left;}

.demo{background:#ccc;}

.item1{background:#F571E3;height:100px;width:100px;}

.item2{background:#21B2F7;height:200px;width:100px;clear: both;}

用 clearfix 清除浮动

清除浮动前,item1左浮动的效果(此时父元素的高是被未浮动的item2元素的高撑开):

2050fb5cb29bfbea6d293b364d9259ef.png

清除浮动前,item1右浮动的效果(此时父元素的高是被未浮动的item2元素的高撑开):

00b388dfb5abe44010de318fe9ef77d6.png

清除浮动后的效果(因为DIV是块级元素,会独占一行,所以item2会在下面一行,此时父元素的高是被item1元素和item2元素的高撑开):

b72be4949cd5f5a70b8d6400cb4defa1.png

2、子元素全部浮动时,给父元素的CSS添加 overflow: hidden;(子元素没有全部浮动时,不浮动的元素会撑开父元素的高,但是由于浮动元素造成的布局应该再利用padding进行修改),但是此方法父元素不能改使用position进行定位,否则不起作用。代码及效果如下:

.demo{background:#ccc;overflow: hidden;}

.item1{background:#F571E3;height:100px;width:100px;}

.item2{background:#21B2F7;height:200px;width:100px;}

清除浮动前的效果,由于父元素的高塌陷,所以背景 background:#ccc; 没有起效果:

dfe176eef33f3443f4cd90d11b5ce803.png

清除浮动后的效果:

76884d43bd32220280f0c92dd4281be7.png

3、给父元素加 伪类:after 和 zoom,代码及效果如下:

.demo{background:#ccc;zoom: 1;}

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

00dfad91c7de4bd7da0a00c1af772198.png

4、如果是在使用bootstrapt,则可以给其父元素添加class 为 clearfix 的类,代码及效果如下:

以上方法各有利弊,大家可以根据自己的理解选择使用,还有一些其他的清除浮动的方法,例如让父元素浮动、让父元素 display:table 等等其他,个人并不推荐使用。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值