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

四个拥有:无论你有多弱或多强,一定要拥有真正爱你的人,拥有知心的朋友,拥有向上的事业,拥有温暖的住所。

需求案例

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

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

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

样式如下:

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;/*用于触发支持IE67inline-block*/
  17. }
  18. .outer.inner{
  19. line-height:1.8;
  20. padding:04px05px;
  21. vertical-align:middle;
  22. width:262px;
  23. }
  24. .outer.v{
  25. line-height:350px;
  26. text-indent:-9999px;
  27. width:1px;
  28. }

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

到此这篇关于CSS在固定宽高的div内如何实现垂直居中的实例详解就介绍到这了。在这个世界上,是有许多事情那都是我们所难以预料的。我们不能去控制际遇,却可以掌握自己;我们无法预知,却可以把握现在;我们不知道自己的到底有多长,但我们却可以安排当下的生活。更多相关CSS在固定宽高的div内如何实现垂直居中的实例详解内容请查看相关栏目,小编编辑不易,再次感谢大家的支持!

您可能有感兴趣的文章
css让页脚保持在底部位置的四种方案

CSS如何使用Flex和Grid布局如何实现3D骰子

Flex布局史上最简单使用语法教程

新的CSS 伪类函数 :is() 和 :where()示例详解

纯CSS打字动画的如何实现示例