CSS水平垂直居中实现总结

在用CSS写布局的时候,经常要用到水平居中与垂直居中。首先看下面这个div:

<body>
<div>
    <span>这是一个例子</span>
</div>
</body>

在body中定义了一个div,div中有一个内联元素span。下面分情况讨论如何让div和span在父容器中水平与垂直居中。

水平居中

  • 块状元素
    要让上述的div水平居中非常简单,利用margin即可。将margin的水平方向设置为auto即可达到水平居中效果。
div{
        width:200px;
        margin:0 auto;
    }
  • 内联元素
    对于文本、图片等内敛元素的居中,可以通过设置其块状元素的父容器中的text-align属性:
    div{
        width:200px;
        margin:0 auto;
        text-align: center;
    }

在上述div中的样式中加入text-align:center的属性,则div中的内联元素就会居中显示。

垂直居中

  • 块状元素
    块状元素的垂直居中可以利用相对定位或者绝对定位,当元素设置相对定位或者绝对定位时,设置其top和left为50%,这样它的左上角就会在已定位的父容器的中间。(注:此处设置相对定位不起作用,因为50%是相对于body的高度的一半,而此时body的高度由div决定。而绝对定位在此处是相对于初始包含块的,也就是画布或者HTML元素。)
    为了让整体元素垂直居中,而不是左上角居中,可以借助margin属性,令其margin-left为负的宽度的一半,margin-top为负的高度的一半。如下:
    div{
        width:200px;
        height: 500px;
        top:50%;
        left:50%;
        position:absolute;
        margin-top:-250px;
        margin-left:-100px;
    }

这样就可以实现div的垂直居中,但是这种方法的前提是需要知道div的宽高,如果不知道的话该怎么办呢?
那就可以利用CSS3中的属性transform

    div{
        top:50%;
        left:50%;
        position:absolute;
        transform: translate(-50%,-50%);
    }

该属性可以相对于自身元素大小的50%进行移动,不用提前指定元素大小,所以相比来说这种方式比上面的margin的方式适应性更强。

  • 内联元素
    内联元素的居中可以通过设置line-height属性来定义:
    span{
        line-height: 300px;
    }

这样该元素就会在这个300px的高度中居中显示。

特殊情况:flex布局

对于父容器为flex布局的块状元素的居中,可以对齐父容器设置:

align-items: center;        /* 垂直居中 */
 justify-content: center;   /* 水平居中 */
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,815评论 1 92
  • 一 外部式css样式 (也可称为外联式)就是把css代码写一个单独的外部文件中,这个css样式文件以“.css...
    KunMitnic阅读 965评论 0 1
  • 本文主要是起笔记的作用,内容来自慕课网. 认识CSS样式 CSS全称为“层叠样式表 (Cascading Styl...
    0o冻僵的企鹅o0阅读 2,665评论 0 30
  • CSS格式化排版 1、字体 我们可以使用css样式为网页中的文字设置字体、字号、颜色等样式属性。下面我们来看一个例...
    张文靖同学阅读 1,310评论 0 3
  • 收听音频,戳链接,旧号itclan已暂停使用,欢迎关注微信itclanCoder公众号可收听更多音频 前言 关于网...
    itclanCoder阅读 8,222评论 3 30