CSS在固定宽高的div内实现垂直居中的实例详解
CSS在固定宽高的div内实现垂直居中的实例详解
发布时间:2016-12-27 来源:查字典编辑
摘要:需求案例案例是这样的,一个外层div,高宽是固定的,但是里面内容不是固定的。很多朋友的做法是头部加一个padding或者margin,这样,...

需求案例

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

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

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

样式是这样的

CSS Code复制内容到剪贴板 .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复制内容到剪贴板 <divclass="outer"> <divclass="inner">haorooms内部内容</div><divclass="v">cssHack</div> </div>

样式如下:

CSS Code复制内容到剪贴板 *{ margin:0; padding:0; } .outer{ background-color:#ccc; font-size:24px; height:350px; text-align:center; overflow:hidden; width:280px; } .outer.inner, .outer.v{ display:inline-block; zoom:1;*display:inline;/*用于触发支持IE67inline-block*/ } .outer.inner{ line-height:1.8; padding:04px05px; vertical-align:middle; width:262px; } .outer.v{ line-height:350px; text-indent:-9999px; width:1px; }

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

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新 Div+Css教程学习
热门 Div+Css教程学习
网页设计子分类