温馨提示×

温馨提示×

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

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

如何使用CSS的overflow属性防止float撑开div

发布时间:2021-03-18 11:13:15 来源:亿速云 阅读:330 作者:小新 栏目:web开发

这篇文章主要介绍了如何使用CSS的overflow属性防止float撑开div,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。

许多应征前端工程师的人,在面试时都会被问到这类float的问题。
例如:div元素内的两个子元素p都float:left,外面的div会变成没有高度,此时该怎么办呢?
通常解法是在排版流里面的元素加一个after的伪元素,将它设成display: block以及clear:both即可解决。

CSS Code复制内容到剪贴板

  1. div:after {content"";displayblock;clearboth;}  

不过我今天意外发现,原来overflow: hidden;也会撑开div呀!如下:
长知识了。

XML/HTML Code复制内容到剪贴板

  1. <body>  

  2.   <div>  

  3.     <p>I am floated</p>  

  4.     <p>So am I</p></div><style>div {   

  5.     overflow: hidden;}p {   

  6.     float: left;}</style>  

深入   
让我们继续深入,来看下面的例子:
编写如下代码,查看效果
HTML代码: 

XML/HTML Code复制内容到剪贴板

  1. <div class="content">  

  2.     <div class="div1">  

  3.   

  4.     </div>  

  5. </div>  

CSS代码:

CSS Code复制内容到剪贴板

  1. .content {   

  2.     border1px solid red;   

  3. }   

  4. .div1 {   

  5.     width100px;   

  6.     height100px;   

  7.     background-color: cyan;   

  8. }  

效果如下:
如何使用CSS的overflow属性防止float撑开div

在content中添加一个div1,并设置了content标签的边框和div1标签的大小和颜色,看到content标签把div1标签包裹起来了。并且还撑起了content标签的大小

但,当我们设置了div1向右浮动的属性之后

CSS Code复制内容到剪贴板

  1. .div1 {   

  2.     width100px;   

  3.     height100px;   

  4.     background-color: cyan;   

  5.     floatrightright;   

  6. }  

就会变成这个样子:
如何使用CSS的overflow属性防止float撑开div

div1标签确实右对齐了,但是并没有撑起content标签的高度。
莫着急,我们需要设置一个属性,就是给content标签,添加overflow属性

添加属性 (overflow: hidden;)

CSS Code复制内容到剪贴板

  1. .content {   

  2.     border1px solid red;   

  3.     overflowhidden;   

  4. }  

添加完之后,效果就成了这样
如何使用CSS的overflow属性防止float撑开div

感谢你能够认真阅读完这篇文章,希望小编分享的“如何使用CSS的overflow属性防止float撑开div”这篇文章对大家有帮助,同时也希望大家多多支持亿速云,关注亿速云行业资讯频道,更多相关知识等着你来学习!

向AI问一下细节

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

AI