栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > Web开发 > Html/CSS > CSS教程

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

CSS教程 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

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

    I am floated

      
  4.     

    So am I

  

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

XML/HTML Code复制内容到剪贴板
  1.   
  2.       
  3.   
  4.     
  
  •   

    CSS代码:

    CSS Code复制内容到剪贴板
    1. .content {   
    2.     border: 1px solid red;   
    3. }   
    4. .div1 {   
    5.     width: 100px;   
    6.     height: 100px;   
    7.     background-color: cyan;   
    8. }  

    效果如下:
    201677113114643.jpg (544×119)

    在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. }  

    就会变成这个样子:
    201677113138628.jpg (592×127)

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

    添加属性 (overflow: hidden;)

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

    添加完之后,效果就成了这样
    201677113202738.jpg (592×116)

    转载请注明:文章转载自 www.mshxw.com
    本文地址:https://www.mshxw.com/it/215808.html

    CSS教程相关栏目本月热门文章

    我们一直用心在做
    关于我们 文章归档 网站地图 联系我们

    版权所有 (c)2021-2022 MSHXW.COM

    ICP备案号:晋ICP备2021003244-6号