固定高宽div垂直居中

 position: absolute; left: 50%; top: 50%; width:200px; height:100px; margin-left:-100px; margin-top:-50px;

不固定高宽div垂直居中的方法

方法一:

用一个“ghost”伪元素(看不见的伪元素)和 inline-block / vertical-align 可以搞定居中,非常巧妙。但是这个方法要求待居中的元素是 inline-block,不是一个真正通用的方案。

html如下:

    
        

haorooms案例题目

        

haorooms案例内容,案例内容haorooms案例内容

    

css如下:

.block {text-align: center;}.block:before {  content: '';  display: inline-block;  height: 100%;  vertical-align: middle;margin-right: -0.25em}.centered {display: inline-block;vertical-align: middle; width: 50%;}

方法二:

可以用table布局方法,但是这种方法也有局限性!

写法如下:

       
          Unknown stuff to be centered.       

由于table写法比较费时,你也可以用div代替table,写法如下:

html:

   
       Unknown stuff to be centered.      

css:

.something-semantic {   display: table;   width: 100%;}.something-else-semantic {   display: table-cell;   text-align: center;   vertical-align: middle;}

css3不定宽高水平垂直居中

justify-content:center;//子元素水平居中align-items:center;//子元素垂直居中display:-webkit-flex;

运用margin:auto进行垂直居中

margin的值设置为auto,可以让我们对剩余空间进行分配!我们知道,块级元素设置为margin:0 auto;可以左右居中显示!那有没有办法让margin设置为margin:auto之后,上下左右都居中呢?上下左右都居中,就可以实现我们的垂直居中了!

答案是有的,只要我们让上下有足够的空间,就可以让margin的auto来分配上下空间。

我们可以利用定位的方式,让margin上下左右都有足够的空间!那么就可以用margin:auto来实现垂直居中了!

实现html如下:(做一个简单的垂直弹框)

    

css代码如下,很简单,兼容性也蛮好,支持IE8+

.father{position:fixed;width:100%;height:100%;top;0;left:0;background-color:rgba(0,0,0,.7);}.son{position: absolute;top:0;left:0;bottom:0;right:0;width:50%;height:50%;margin:auto;background-color:red;}