如何用css实现元素水平与垂直居中

如果文章对你有帮助,请点喜欢并关注,这将是我最大的动力,谢谢

1.水平居中

1.1.文字,图片以及内联元素:

如果希望居中的是内联元素或者是文字图片
text-align:center;

1.2.块状元素

1.2.1.对于已设置宽度的块状元素:

margin:0 auto;----------------------让margin的左右自适应,通常是居中

1.2.2.对于未设置宽度的块状元素:

1.使用table标签
html:

<table>
        <tr>
            <td>
                <div id="container"></div>
            </td>
        </tr>
    </table>

css:

table{
     margin:0 auto;
}

这个不常用,因为添加了更多无意义的标签
2.通过将子块状元素变成行内元素
html:

<div>
    <p>居中示例</p>
</div>

css:

p{
     display:inline;
}
div{
     text-align:center;
}

假设p在div内部,要让p居中
先给外层元素设置text-align:center,这个意思是让div里面的内联元素居中,然后将p变成内联元素,即可。
3.通过position
html:

<div>
    <p>居中示例</p>
</div>

css:

div{
     float:left;  
     position:relative; 
     left:50%;
}
p{
     position:relative;  
     right:50%;
}

float:left,目的是让父元素靠左并且宽度与子元素等宽;然后相对于原先的位置,向右移动50%,此时该元素的left为50%+(50%父元素自身宽度)
然后将子元素相对于原先的位置,向左移动50%(这50%是基于父元素的宽度),此时居中。

2.垂直居中

2.1.对于已设置高度的单行文本

只需将父元素的height值与line-height的值设置相同即可

2.2.对于已设置高度的多行文本

1.使用table标签
html:

    <table>
        <tr>
            <td>
                <p>aaaaa</p>
                <p>aaaaa</p>   
                <p>aaaaa</p>
            </td>
        </tr>
    </table>

css:

table{
            height: 500px;
            background-color: #aaa;
        }

因为table标签中的td拥有标签隐式的样式:vertical-align:middle;
2.通过table-cell
html:

   <p>aaaaa</p>
   <p>aaaaa</p>   
   <p>aaaaa</p>

css:

p{
     display:table-cell;
     vertical-align:middle;
}

table-cell的意思是让元素以表格单元的形似表现,但是只支持IE8以上浏览器​

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

推荐阅读更多精彩内容

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