首页 > 开发 > CSS > 正文

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

2024-07-11 08:32:53
字体:
来源:转载
供稿:网友

需求案例

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

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

CSS Code复制内容到剪贴板
  1. <div class="outer"><div class="inner">haorooms内部内容</div></div>  

样式是这样的

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. <div class="outer">        <div class="inner">haorooms内部内容</div><div class="v">cssHack</div>   
  2. </div>  

样式如下:

CSS Code复制内容到剪贴板
  1. * {        margin: 0;   
  2.     padding: 0;    }   
  3. .outer {        background-color: #ccc;   
  4.     font-size: 24px;        height: 350px;   
  5.     text-align: center;        overflow: hidden;   
  6.     width: 280px;    }   
  7. .outer  .inner,    .outer  .v {   
  8.     display: inline-block;        zoom: 1;*display: inline; /* 用于触发支持IE67 inline-block */  
  9. }    .outer  .inner {               
  10.     line-height: 1.8;        padding: 0 4px 0 5px;   
发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表