网页制作 
首页 > 网页制作 > 浏览文章

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

(编辑:jimmy 日期: 2024/11/19 浏览:3 次 )

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

CSS Code复制内容到剪贴板
  1. div:after {content: "";display: block;clear: both;}  

不过我今天意外发现,原来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.     border: 1px solid red;   
  3. }   
  4. .div1 {   
  5.     width: 100px;   
  6.     height: 100px;   
  7.     background-color: cyan;   
  8. }  

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

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

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

CSS Code复制内容到剪贴板
  1. .div1 {   
  2.     width: 100px;   
  3.     height: 100px;   
  4.     background-color: cyan;   
  5.     float: rightright;   
  6. }  

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

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

添加属性 (overflow: hidden;)

CSS Code复制内容到剪贴板
  1. .content {   
  2.     border: 1px solid red;   
  3.     overflow: hidden;   
  4. }  

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

上一篇:CSS的clear属性清除浮动的基本用法示例
下一篇:CSS隐藏页面元素的5种方法
一句话新闻
一文看懂荣耀MagicBook Pro 16
荣耀猎人回归!七大亮点看懂不只是轻薄本,更是游戏本的MagicBook Pro 16.
人们对于笔记本电脑有一个固有印象:要么轻薄但性能一般,要么性能强劲但笨重臃肿。然而,今年荣耀新推出的MagicBook Pro 16刷新了人们的认知——发布会上,荣耀宣布猎人游戏本正式回归,称其继承了荣耀 HUNTER 基因,并自信地为其打出“轻薄本,更是游戏本”的口号。
众所周知,寻求轻薄本的用户普遍更看重便携性、外观造型、静谧性和打字办公等用机体验,而寻求游戏本的用户则普遍更看重硬件配置、性能释放等硬核指标。把两个看似难以相干的产品融合到一起,我们不禁对它产生了强烈的好奇:作为代表荣耀猎人游戏本的跨界新物种,它究竟做了哪些平衡以兼顾不同人群的各类需求呢?