详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)
脚本之家 / 编程助手:解决程序员“几乎”所有问题!
脚本之家官方知识库 → 点击立即使用
一. overflow:hidden 溢出隐藏
给一个元素中设置overflow:hidden,那么该元素的内容若超出了给定的宽度和高度属性,那么超出的部分将会被隐藏,不占位。
1 2 3 4 5 6 7 8 9 10 11 12 | /*css样式*/ <style type= "text/css" > div{ width : 150px ; height : 60px ; background : skyblue; overflow : hidden ; /*溢出隐藏*/ } </style> /*html*/ <div style= "" > 今天天气很好!<br>今天天气很好!<br> 今天天气很好!<br>今天天气很好!<br> </div> |
效果如下:
一般情况下,在页面中,一般溢出后会显示省略号,比如,当一行文本超出固定宽度就隐藏超出的内容显示省略号。
1 2 3 4 5 6 7 8 | /*只适用于单行文本*/ div{ width : 150px ; background : skyblue; overflow : hidden ; /*溢出隐藏*/ white-space : nowrap ; /*规定文本不进行换行*/ text- overflow : ellipsis; /*当对象内文本溢出时显示省略标记(...)*/ } |
效果如下:
二. overflow:hidden 清除浮动
一般而言,父级元素不设置高度时,高度由随内容增加自适应高度。当父级元素内部的子元素全部都设置浮动float之后,子元素会脱离标准流,不占位,父级元素检测不到子元素的高度,父级元素高度为0。那么问题来了,如下:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 | /*css样式*/ < style type = "text/css" > .box{ background:skyblue; } .kid{ width: 100px;height: 100px; float:left;} .kid1{ background: yellow; } .kid2{ background: orange; } .wrap{ width: 300px; height: 150px; background: blue; color: white; } </ style > /*html*/ < body > < div class = "box" > < div class = "kid kid1" >子元素1</ div > < div class = "kid kid2" >子元素2</ div > </ div > < div class = "wrap" >其他部分</ div > </ body > |
如上,由于父级元素没有高度,下面的元素会顶上去,造成页面的塌陷。因此,需要给父级加个overflow:hidden属性,这样父级的高度就随子级容器及子级内容的高度而自适应。如下:
由于在IE比较低版本的浏览器中使用overflow:hidden;是不能达到这样的效果,因此需要加上 zoom:1;
所以为了让兼容性更好的话,如果需要使用overflow:hidden来清除浮动,那么最好加上zoom:1;
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 | /*css样式*/ < style type = "text/css" > .box{ background:skyblue; overflow: hidden; /*清除浮动*/ zoom:1; } .kid{ width: 100px;height: 100px; float:left;} .kid1{ background: yellow; } .kid2{ background: orange; } .wrap{ width: 300px; height: 150px; background: blue; color: white; } </ style > /*html*/ < body > < div class = "box" > < div class = "kid kid1" >子元素1</ div > < div class = "kid kid2" >子元素2</ div > </ div > < div class = "wrap" >其他部分</ div > </ body > |
三. overflow:hidden 解决外边距塌陷
父级元素内部有子元素,如果给子元素添加margin-top样式,那么父级元素也会跟着下来,造成外边距塌陷,如下:
1 2 3 4 5 6 7 8 9 10 11 12 | /*css样式*/ < style type = "text/css" > .box{ background:skyblue;} .kid{ width: 100px;height: 100px; background: yellow; margin-top: 20px} </ style > /*html*/ < body > < div class = "box" > < div class = "kid" >子元素1</ div > </ div > </ body > |
因此,给父级元素添加overflow:hidden,就可以解决这个问题了。
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | /*css样式*/ < style type = "text/css" > .box{ background:skyblue; overflow: hidden; /*解决外边距塌陷*/ } .kid{ width: 100px;height: 100px; background: yellow; margin-top: 20px} </ style > /*html*/ < body > < div class = "box" > < div class = "kid" >子元素1</ div > </ div > </ body > |
到此这篇关于详解overflow:hidden的作用(溢出隐藏、清除浮动、解决外边距塌陷)的文章就介绍到这了,更多相关overflow:hidden的作用 内容请搜索脚本之家以前的文章或继续浏览下面的相关文章,希望大家以后多多支持脚本之家!
相关文章
- 这篇文章主要介绍了CSS中如何解决外边距塌陷问题,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习2020-05-11
- margin-top塌陷是在CSS的盒子模型中出现的一种现象,本文就介绍了CSS中外边距塌陷的八种解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学2023-05-31
最新评论