美文网首页
div中内容上下居中小结

div中内容上下居中小结

作者: 忘了呼吸的那只猫 | 来源:发表于2018-11-15 12:48 被阅读20次

    情形一: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>
    <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>
    

    相关文章

      网友评论

          本文标题:div中内容上下居中小结

          本文链接:https://www.haomeiwen.com/subject/olqyfqtx.html