css实现水平垂直居中的方法总结

css实现水平垂直居中的方法总结

实现水平垂直居中你有多少种方法?这是前端面试必考题啊!-=- 这段时间公司招前端听了一堆五花八门的答案,现在简单总结下!
分两种情况,第一种是,固定宽高在父元素中水平垂直居中,另外一种就是宽高不定的元素在父元素中水平垂直居中,注意第二种其实页适用于宽高固定的情况

公共样式如下:wrap是父级元素,inner是要居中的元素,innerSiz用于定宽高

.wrap {
    border: 1px solid red;
    width: 300px;
    height: 300px;
}

.inner {
    background: green;
}

.inner.innerSize{
    width: 100px;
    height: 100px;
}
元素固定宽高

定宽高的结构如下:

<!-- 定宽高结构 -->
<div class="wrap">
    <div class="inner innerSize">我要居中</div>
</div>
方法一:position + 上下margin负自身宽高的一半
.wrap{
    position: relative;
}
.inner{
    position: absolute;
    top: 50%;
    left: 50%;
    margin-top: -50px;
    margin-left: -50px;
}
方法二:position + margin:auto
.wrap{
    position: relative;
}
.inner{
    position: absolute;
    top: 0;
    right: 0;
    left: 0;
    bottom: 0;
    margin: auto;
}
方法三:position + calc
.wrap{
    position: relative;
}
.inner{
    position: absolute;
    top: calc(50% - 50px);
    left: calc(50% - 50px);
}
元素不定宽高的情况(也适用于固定宽高的情况)

不定宽高的结构如下:

<!-- 定宽高结构 -->
<div class="wrap">
    <div class="inner">我要居中</div>
</div>
方法一:position + transform
.wrap{
    position: relative;
}
.inner{
    position: absolute;
    top: 50%;
    left: 50%;
    transform: translate(-50%, -50%);
}
方法二:flex
.wrap{
    display: flex;
    justify-content: center;
    align-items: center;
}
.inner{}
方法三:table
.wrap{
    display: table-cell;
    text-align: center;
    vertical-align: middle;
}
.inner{
    display: inline-block;
}
方法三:gird布局
.wrap {
    display: grid;
}
.inner {
    align-self: center;
    justify-self: center;
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 收听音频,戳链接,旧号itclan已暂停使用,欢迎关注微信itclanCoder公众号可收听更多音频 前言 关于网...
    itclanCoder阅读 12,531评论 3 30
  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,683评论 1 92
  • 1.绝对定位居中技术 我们一直用margin:auto实现水平居中,而一直认为margin:auto不能实现垂直居...
    DecadeHeart阅读 5,499评论 0 3
  • 一 外部式css样式 (也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css...
    KunMitnic阅读 4,576评论 0 1
  • 01 昨晚,和精进读书会的小伙伴聚会后,到家已经快11点了。我早上5点就起床,跑出去上课,下课后赶去和大家聚会,累...
    作家格格阅读 2,548评论 0 1