div中内容上下居中⼩结
虽然div中内容上下居中的问题已经是⼀个⽐较古⽼的话题,但是最近发现还是有很多前端开发者在询问如何实现。其实⽹络上已经有很多资料和案例了,我这⾥再总结⼀下⼏个⽐较常见的处理⽅式。
情形⼀:div限⾼,内容长度限⼀⾏
复制代码
代码如下:
<style>
.v-align {
margin: 0 auto;
width: 200px;
height: 80px;
text-align: center;
line-height: 80px;
border: 1px solid #ddd;
}
</style>
<!-- html -->
<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%;
}
<!-- html -->
<div class="v-mult">
<span class="empty"></span>
css设置文字垂直居中
<span class="text">我的内容不限,多⾼都⾏
换⾏照常</span>
</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;
}
<!-- html -->
<div class="v-auto">
<div class="text">
我的⾼度是固定的,只有100px⾼,但是我的⽗及⾼度不定,我怎么垂直居中呢?</div>
</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%);
}
<!-- html -->
<div class="v-auto-out">
<div class="auto-in">我的⾼度不定,我的⽗及⾼度也不定,这下要上下居中,该如何是好?我们⼀起来瞧瞧吧。</div>
</div>
好了,知道这四种⽅式,我相信⾜以应对⽇常⼯作中的各种垂直居中问题。代码很简单,不再做多余阐述。总之⼀句
话,CSS的各个属性样式,就好像⼈肢体的各个器官,了解了各个器官的功能,才能相互配合完成各种任务。相反,个体的能⼒是有限的。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。