• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    迪恩网络公众号

使用CSS的overflow属性防止float撑开div的方法

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

许多应征前端工程师的人,在面试时都会被问到这类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. }  

效果如下:

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

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

CSS Code复制内容到剪贴板
  1. .div1 {   
  2.     width100px;   
  3.     height100px;   
  4.     background-color: cyan;   
  5.     floatrightright;   
  6. }  

就会变成这个样子:

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

添加属性 (overflow: hidden;)

CSS Code复制内容到剪贴板
  1. .content {   
  2.     border1px solid red;   
  3.     overflowhidden;   
  4. }  

添加完之后,效果就成了这样


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
CSS隐藏页面元素的5种方法发布时间:2022-06-21
下一篇:
CSS的clear属性清除浮动的基本用法示例发布时间:2022-06-21
热门推荐
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap