手机
当前位置:查字典教程网 >网页设计 > Div+Css教程 >使用CSS的overflow属性防止float撑开div的方法
使用CSS的overflow属性防止float撑开div的方法
摘要:许多应征前端工程师的人,在面试时都会被问到这类float的问题。例如:div元素内的两个子元素p都float:left,外面的div会变成没...

许多应征前端工程师的人,在面试时都会被问到这类float的问题。

例如:div元素内的两个子元素p都float:left,外面的div会变成没有高度,此时该怎么办呢?

通常解法是在排版流里面的元素加一个after的伪元素,将它设成display: block以及clear:both即可解决。

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

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

长知识了。

XML/HTML Code复制内容到剪贴板 <body> <div> <p>Iamfloated</p> <p>SoamI</p></div><style>div{ overflow:hidden;}p{ float:left;}</style>

深入

让我们继续深入,来看下面的例子:

编写如下代码,查看效果

HTML代码:

XML/HTML Code复制内容到剪贴板 <divclass="content"> <divclass="div1"> </div> </div>

CSS代码:

CSS Code复制内容到剪贴板 .content{ border:1pxsolidred; } .div1{ width:100px; height:100px; background-color:cyan; }

效果如下:

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

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

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

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

就会变成这个样子:

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

div1标签确实右对齐了,但是并没有撑起content标签的高度。

莫着急,我们需要设置一个属性,就是给content标签,添加overflow属性

添加属性 (overflow: hidden;)

CSS Code复制内容到剪贴板 .content{ border:1pxsolidred; overflow:hidden; }

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

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

【使用CSS的overflow属性防止float撑开div的方法】相关文章:

用CSS的float属性创建三栏布局网页的方法

CSS强制换行对齐的实现方法

CSS中的!important属性用法

关于DIVCSS浮动float的兼容

CSS定位属性Position详解

CSS浮动属性Float详解

css 的border属性改变hr颜色小示例

CSS隐藏文字的方法

CSS让ul所有的li居中显示的方法

firefox中div+css的外层背景色不见的解决方法

精品推荐
分类导航