转载的(http://www.cnblogs.com/mawuhen/p/4055347.html)这是原文路径
情形一:div限高,内容长度限一行
.v-align { margin: 0 auto; width: 200px; height: 80px; text-align: center; line-height: 80px; border: 1px solid #ddd; }
1 <div class="v-align">我的内容只能有一行。</div>
情形二:div限高,内容不限
.v-mult { margin: 0 auto; width: 200px; height: 100px; border: 1px solid #ddd; overflow: hidden; } .v-mult .empty, .v-mult .text { display: inline-block; *display: inline; *zoom: 1; vertical-align: middle; } .v-mult .empty { height: 100%; }
1 <div class="v-mult">
2 <span class="empty"></span>
3 <span class="text">我的内容不限,多高都行<br>换行照常</span>
4 </div>
情形三:div高度不定,内容高度一定
.v-auto { position: relative; margin: 0 auto; width: 200px; border: 1px solid #ddd; } .v-auto .text { position: absolute; top: 50%; margin-top: -50px; height: 100px; border: 1px dashed #ddd; }
1 <div class="v-auto">
2 <div class="text">
3 我的高度是固定的,只有100px高,但是我的父及高度不定,我怎么垂直居中呢?
4 </div>
5 <br><br><br><br><br><br><br><br>
6 </div>
情形四:div高度不定,内容高度不定
.v-auto-out { position: relative; margin: 0 auto; width: 200px; border: 1px solid #ddd; } .v-auto-out .auto-in { position: absolute; top: 50%; border: 1px dashed #ddd; /* 这里有兼容性问题 */ -webkit-transform: translateY(-50%); -ms-transform: translateY(-50%); -o-transform: translateY(-50%); transform: translateY(-50%); }
1 <div class="v-auto-out">
2 <div class="auto-in">我的高度不定,我的父及高度也不定,这下要上下居中,该如何是好?我们一起来瞧瞧吧。</div>
3 <br><br><br><br><br><br><br><br><br>
4 </div>

浙公网安备 33010602011771号