温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

DIV+CSS清除浮动常用方法有哪些

发布时间:2021-08-10 22:00:04 来源:亿速云 阅读:146 作者:chen 栏目:web开发

这篇文章主要介绍“DIV+CSS清除浮动常用方法有哪些”,在日常操作中,相信很多人在DIV+CSS清除浮动常用方法有哪些问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”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;clearboth;}    

  6. </style>    

  7. </head>    

  8. <body>    

  9.     <h3>用 clearfix 清除浮动</h3>    

  10.     <div class="demo">    

  11.         <div class="fl item1"></div>    

  12.         <div class="item2"></div>    

  13.     </div>    

  14. </body>  

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

DIV+CSS清除浮动常用方法有哪些

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

DIV+CSS清除浮动常用方法有哪些

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

DIV+CSS清除浮动常用方法有哪些

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

CSS Code复制内容到剪贴板

  1. <style type="text/css">    

  2. .fl{float:left;}    

  3. .demo{background:#ccc;overflowhidden;}    

  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; 没有起效果:

DIV+CSS清除浮动常用方法有哪些

清除浮动后的效果:

DIV+CSS清除浮动常用方法有哪些

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; 没有起效果:

DIV+CSS清除浮动常用方法有哪些


清除浮动后的效果:

DIV+CSS清除浮动常用方法有哪些

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>  

清除浮动后的效果:

DIV+CSS清除浮动常用方法有哪些

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

到此,关于“DIV+CSS清除浮动常用方法有哪些”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI