首页前端开发HTMLCSS在固定宽高的div内实现垂直居中的实例详解

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

时间2024-01-24 06:02:42发布访客分类HTML浏览621
导读:收集整理的这篇文章主要介绍了CSS在固定宽高的div内实现垂直居中的实例详解,觉得挺不错的,现在分享给大家,也给大家做个参考。 需求案例案例是这样的,一个外层div,高宽是固定的,但是里面内容不是固定的。很多朋友的做法是头部加一个...
收集整理的这篇文章主要介绍了CSS在固定宽高的div内实现垂直居中的实例详解,觉得挺不错的,现在分享给大家,也给大家做个参考。

需求案例

案例是这样的,一个外层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-alignmiddle; width:200px; height:350px; }   

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

解决方法

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

div如下:

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

样式如下:

CSS Code复制内容到剪贴板
  1. * {   
  2.     margin: 0;   
  3.     padding: 0;   
  4. }   
  5. .outer {   
  6.     background-color#ccc;   
  7.     font-size24px;   
  8.     height350px;   
  9.     text-aligncenter;   
  10.     overflowhidden;   
  11.     width280px;   
  12. }   
  13. .outer  .inner,   
  14. .outer  .v {   
  15.     displayinline-block;   
  16.     zoom: 1; *displayinline;  /* 用于触发支持IE67 inline-block */  
  17. }   
  18. .outer  .inner {                
  19.     line-height: 1.8;   
  20.     padding: 0 4px 0 5px;   
  21.     vertical-alignmiddle;   
  22.     width262px;               
  23. }   
  24. .outer  .v {   
  25.     line-height350px;   
  26.     text-indent:-9999px;   
  27.     width1px;             
  28. }   

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

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!

CSSdiv

若转载请注明出处: CSS在固定宽高的div内实现垂直居中的实例详解
本文地址: https://pptw.com/jishu/585093.html
使用CSS实现弹性视频html5案例实践 HTML5中实现拖放效果无须借助javascript

游客 回复需填写必要信息