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

CSS在固定宽高的div内实现垂直居中的实例详解

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

CSS在固定宽高的div内实现垂直居中的实例详解

需求案例

案例是这样的,一个外层div,高宽是固定的,但是里面内容不是固定的。很多朋友的做法是头部加一个padding或者margin,这样,里面内容显得貌似是居中了,但是假如内容变化,这样头部的固定padding或者margin,始终不变。造成了垂直方向不会居中!

我们知道,假如下面一个div

CSS Code复制内容到剪贴板
  1. "outer">"inner">haorooms内部内容  

样式是这样的

CSS Code复制内容到剪贴板
  1. .outer{text-align:center;vertical-align: middle;width:200px;height:350px;}  

vertical-align:middle是不管用的,很多朋友就在.inner上面做文章了,和我上面说的,加margin等等!那对于这种情况,有没有更好的解决方案呢?

解决方法

思路:加一个cssHack,设置cssHack的line-height等于外层div的高度,就可以使用vertical-align:middle了!

div如下:

CSS Code复制内容到剪贴板
  1. "outer">   
  2.     "inner">haorooms内部内容"v">cssHack   
  3.   

样式如下:

CSS Code复制内容到剪贴板
  1. * {   
  2.     margin: 0;   
  3.     padding: 0;   
  4. }   
  5. .outer {   
  6.     background-color: #ccc;   
  7.     font-size: 24px;   
  8.     height: 350px;   
  9.     text-align: center;   
  10.     overflow: hidden;   
  11.     width: 280px;   
  12. }   
  13. .outer  .inner,   
  14. .outer  .v {   
  15.     display: inline-block;   
  16.     zoom: 1;*display: inline;   
  17. }   
  18. .outer  .inner {               
  19.     line-height: 1.8;   
  20.     padding: 0 4px 0 5px;   
  21.     vertical-align: middle;   
  22.     width: 262px;              
  23. }   
  24. .outer  .v {   
  25.     line-height: 350px;   
  26.     text-indent:-9999px;   
  27.     width: 1px;            
  28. }  

这样就实现了div内部的垂直居中了!

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/215842.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

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

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