固定高宽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;}