源码网,源码论坛,源码之家,商业源码,游戏源码下载,discuz插件,棋牌源码下载,精品源码论坛

 找回密码
 立即注册
楼主: ttx9n

[CSS] DIV+CSS 清除浮动常用方法总结

[复制链接]

7万

主题

861

回帖

32万

积分

论坛元老

Rank: 8Rank: 8

积分
329525
发表于 2016-5-6 15:10:41 | 显示全部楼层 |阅读模式
下面小编就为大家带来一篇DIV+CSS 清除浮动常用方法总结。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

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

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

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

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

CSS Code复制内容到剪贴板
  1. <style type="text/css">    
  2. .fl{float:left;}    
  3. .demo{background:#ccc;}    
  4. .item1{background:#F571E3;height:100px;width:100px;}    
  5. .item2{background:#21B2F7;height:200px;width:100px;clear: both;}    
  6. </style>    
  7. </head>    
  8. <body>    
  9.     <h2>用 clearfix 清除浮动</h2>    
  10.     <div class="demo">    
  11.         <div class="fl item1"></div>    
  12.         <div class="item2"></div>    
  13.     </div>    
  14. </body>  

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

20160506151150250.png

20160506151150250.png

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

20160506151150251.png

20160506151150251.png

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

20160506151150252.png

20160506151150252.png

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

CSS Code复制内容到剪贴板
  1. <style type="text/css">    
  2. .fl{float:left;}    
  3. .demo{background:#ccc;overflow: hidden;}    
  4. .item1{background:#F571E3;height:100px;width:100px;}    
  5. .item2{background:#21B2F7;height:200px;width:100px;}    
  6. </style>    
  7. </head>    
  8. <body>    
  9.     <div class="demo">    
  10.         <div class="fl item1"></div>    
  11.         <div class="fl item2"></div>    
  12.     </div>    
  13. </body>  

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

20160506151150253.png

20160506151150253.png

 

清除浮动后的效果:

20160506151150254.png

20160506151150254.png

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

CSS Code复制内容到剪贴板
  1. <style type="text/css">    
  2. .fl{float:left;}    
  3. .demo{background:#ccc;zoom: 1;}    
  4. .demo:after{display:block;clear:both;content:"";visibility:hidden;height:0}   
  5. .item1{background:#F571E3;height:100px;width:100px;}    
  6. .item2{background:#21B2F7;height:200px;width:100px;}    
  7. </style>    
  8. </head>    
  9. <body>    
  10.     <div class="demo">    
  11.         <div class="fl item1"></div>    
  12.         <div class="fl item2"></div>    
  13.     </div>    
  14. </body>  

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


清除浮动后的效果:

20160506151150255.png

20160506151150255.png

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

CSS Code复制内容到剪贴板
  1. <style type="text/css">    
  2. .fl{float:left;}    
  3. .demo{background:#ccc;}    
  4. .item1{background:#F571E3;height:100px;width:100px;}    
  5. .item2{background:#21B2F7;height:200px;width:100px;}    
  6. </style>    
  7. </head>    
  8. <body>    
  9.     <div class="demo clearfix">    
  10.         <div class="fl item1"></div>    
  11.         <div class="fl item2"></div>    
  12.     </div>    
  13. </body>  

清除浮动后的效果:

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

以上这篇DIV+CSS 清除浮动常用方法总结就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

原文地址:http://www.cnblogs.com/Lily-nercel/archive/2016/05/06/5465592.html

回复

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-8-25 15:12:14 | 显示全部楼层
管灌灌灌灌灌灌灌灌灌灌
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2022-10-5 12:34:17 | 显示全部楼层
撒房产税陈飞飞
回复 支持 反对

使用道具 举报

29

主题

2万

回帖

194

积分

注册会员

Rank: 2

积分
194
发表于 2022-10-29 21:18:40 | 显示全部楼层
抽根烟,下来看看再说
回复 支持 反对

使用道具 举报

7

主题

2万

回帖

288

积分

中级会员

Rank: 3Rank: 3

积分
288
发表于 2022-11-2 06:29:54 | 显示全部楼层
灌灌灌灌水
回复 支持 反对

使用道具 举报

11

主题

2万

回帖

300

积分

中级会员

Rank: 3Rank: 3

积分
300
发表于 2022-12-6 06:04:48 | 显示全部楼层
给爸爸爸爸爸爸爸爸爸爸八佰伴八佰伴
回复 支持 反对

使用道具 举报

4

主题

2万

回帖

107

积分

注册会员

Rank: 2

积分
107
发表于 2023-3-25 18:37:56 | 显示全部楼层
女生看了弄丢了卡萨诺的卡洛斯
回复 支持 反对

使用道具 举报

7

主题

2万

回帖

288

积分

中级会员

Rank: 3Rank: 3

积分
288
发表于 2023-8-13 17:00:44 | 显示全部楼层
来看看怎么样
回复 支持 反对

使用道具 举报

0

主题

1万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-8-22 02:35:48 | 显示全部楼层
8888888888888888
回复 支持 反对

使用道具 举报

0

主题

2万

回帖

0

积分

中级会员

Rank: 3Rank: 3

积分
0
发表于 2023-8-26 05:39:05 | 显示全部楼层
不错的源码论坛
回复 支持 反对

使用道具 举报

高级模式
B Color Image Link Quote Code Smilies

本版积分规则

手机版|小黑屋|网站地图|源码论坛 ( 海外版 )

GMT+8, 2025-2-5 12:54 , Processed in 0.071160 second(s), 25 queries .

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

快速回复 返回顶部 返回列表