垂直水平居中的几种常用方案

垂直水平居中的方案有很多,有时候容易搞混。
其实细分下来主要有两种场景:元素宽高未知的场景、元素宽高已知的场景。针对这两种情况,后文分别列出集中主流的垂直水平居中方案。

元素宽高未知的场景

table 实现垂直水平居中【推荐】

table垂直水平居中方案,是万金油方案,适用性极强,也没有兼容性问题;缺陷是会增加冗余的HTML结构。

<div class="vertical center">
    <div class="box-container">
        <span class="box">haha</span>
    </div>
</div>

.vertical {
    width: 100%;
    height: 100%;
    display: table;
}
.vertical.center {
    text-align: center;
}

.vertical .box-container {
    display: table-cell;
    vertical-align: middle;
}

.vertical .box-container .box {
    vertical-align: middle;
}

transform 实现垂直水平居中【推荐】

transform垂直水平居中方案,同样也是万金油方案,尤其适合移动端;缺陷是只支持IE9及以上的浏览器。

<span class="box">haha</span>

// transform是以自身宽高为基准计算的
.box {
    position: relative; 
    left: 50%; 
    top: 50%;
    transform: translate(-50%, -50%);    
}

flexbox 实现垂直水平居中

移动端可以使用;缺陷是只支持IE10及以上的浏览器。

<div class="box-container">
    <span class="box"></span>
</div>

// transform是以自身宽高为基准计算的
.box-container {
    display: -webkit-flex;
    display: -moz-flex;
    display: -ms-flex;
    display: -o-flex;
    display: flex;
    justify-content: center;
    align-items: center;
}

元素宽高已知的场景

绝对定位 实现垂直水平居中

比较常用的方案,需要已知宽高。

<div class="box-container">
    <span class="box"></span>
</div>

.box-container{
    position: relative;
}
.box-container .box {
    width: 600px; 
    height: 400px;
    position: absolute; 
    left: 50%; 
    top: 50%;
    margin-top: -200px;    /* 高度的一半 */
    margin-left: -300px;    /* 宽度的一半 */
}

margin:auto 实现垂直水平居中

特别适合自身有宽高的元素,比如图片等;但是对于其他元素,仍然需要显式设置宽高。

// 图片等自身带宽高的元素,直接 margin: auto; 即可
<div class="box-container">
    <img class="box" />
</div>

.box-container{
    position: relative;
}
.img {
    position: absolute; 
    left: 0; 
    top: 0; 
    right: 0; 
    bottom: 0;
    margin: auto;
}

// 其他场景需要显式设置宽高
<div class="box-container">
    <span class="box"></span>
</div>
.box-container{
    position: relative;
}
.box {
    width: 100px;
    height: 100px;
    position: absolute; 
    left: 0; 
    top: 0; 
    right: 0; 
    bottom: 0;
    margin: auto;
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 收听音频,戳链接,旧号itclan已暂停使用,欢迎关注微信itclanCoder公众号可收听更多音频 前言 关于网...
    itclanCoder阅读 8,323评论 3 30
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,052评论 1 92
  • 在页面布局中,居中在各种各样的场景中广泛被用到,也经常被新人提及。以前做过一些自己探索居中问题的demo,今天翻出...
    彬_仔阅读 364评论 0 6
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 178,296评论 25 709
  • 南乡隐子阅读 488评论 0 0

友情链接更多精彩内容