你尚未登录,仅允许查看本站部分内容。请登录使用邀请码注册
MrZheng

还记得我们折腾过的居中么? 4个回复 专栏 @ CSS

MrZheng 发布于 2 年前

虽然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>

valign_1

情形二: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>
    <span class="text">我的内容不限,多高都行<br>换行照常</span>
</div>

valign_2

情形三: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>
    <br><br><br><br><br><br><br><br>
</div>

valign_3

情形四: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>
    <br><br><br><br><br><br><br><br><br>
</div>

valign_4

好了,知道这四种方式,我相信足以应对日常工作中的各种垂直居中问题。代码很简单,不再做多余阐述。总之一句话,CSS的各个属性样式,就好像人肢体的各个器官,了解了各个器官的功能,才能相互配合完成各种任务。相反,个体的能力是有限的。

作者博客:百码山庄

  • berg

    话说我好久没有折腾过居中这么一回事了

    #1
  • 三点

    嘤嘤嘤,还可以这样:

    .container {
      display: flex;
      align-items:center;    
      justify-content:center;    
    }
    
    <div class="container">
      <div class="inner"></div>
    </div>
    

    示例

    #2
  • linxz

    看来看去,对于居中最好的办法还是表格……

    #3
  • wangdaodao

    还有这个writing-mode: tb-rl;

    #4
登录后回复,如无账号,请使用邀请码注册