CSS常见居中方法大团圆

Markdown

还有几天就是农历新年了,于我们而言这是个举国欢庆、阖家团员的大日子。提前祝各位朋友新年快乐,家人健康。
言归正传,借这个机会抽时间总结了一下css中常见的居中方法,也让它们沾沾喜气团圆一下。
css元素的居中可以分为三类:水平居中,垂直剧中,水平&垂直居中。其中行内元素、宽高固定的块元素、宽高不固定的块元素居中方法又各有千秋,接下来分门别类为大家一一道来。

1 水平居中

1.1 行内元素居中

对象:
行内元素(text、img、button等);
display为inline-bloc的非浮动块元素;
方法:
父元素设置text-align:center;

1.2 单个块元素(固定宽度)居中

方法:
为元素设置margin:0 auto即可;

1.3 多个块元素(宽度固定)水平排列居中

Markdown

方法1:
要居中的块元素设置display:inline-block变为行内块元素(不能用flaot),然后给其父元素设置text-align:center即可。
请看代码示例:

<style>
    ul,li {    list-style: none;    }

    ul {
        height: 200px;
        background-color: #C3BED4;
        /*实现居中*/
        text-align: center;
    }
    li {
        width: 100px;
        height: 100px;
        background-color: #EEEEFF;
        margin: 10px;
        /*变为行内块元素,记住要去掉浮动。*/
        display: inline-block;
    }
</style>
<body>
    <ul>
        <li>我的数量不确定,但都会居中显示。</li>
        <li>我的数量不确定,但都会居中显示。</li>
    </ul>
</body>

方法2(flex):
要居中的父元素设置display:flex和justify-content:center即可。
代码示例:

<style>
    ul,li {    list-style: none;    }

    ul {
        height: 200px;
        background-color: #C3BED4;
        /*父元素变为flex弹性盒子实现内部子元素水平居中。*/
        display: flex;
        justify-content: center;
    }
    li {
        width: 100px;
        height: 100px;
        background-color: #EEEEFF;
        margin: 10px;
        float: left;
    }
</style>
<body>
    <ul>
        <li>我的数量不确定,但都会居中显示。</li>
        <li>我的数量不确定,但都会居中显示。</li>
    </ul>
</body>

1.4 块元素(宽度不固定)居中

Markdown

方法1:
要居中的元素设置display:table,再设置margin:auto。
原理:
利用table元素有宽度自适应的特性,即不定义其宽度也不默认父元素body的宽度(table其宽度根据其内文本宽度决定)。因此可以看做一个定宽度块元素,然后再利用定宽度块状居中的margin的方法,使其水平居中。
代码示例:

<style>
    .father {
        border: 1px solid #376956;
        overflow: hidden;
        /*下面两个组合实现没有宽度的块元素水平居中。*/
        margin: 0 auto;
        display: table;
    }
    .son {
        width: 100px;
        height: 100px;
        background-color: #c3bed4;
        float: left;
        margin: 10px;
    }
</style>
<body>
    <div class="father">
        <div class="son">我的数量不确定,意味着父元素不能设置固定宽度。</div>
        <div class="son">我的数量不确定,意味着父元素不能设置固定宽度。</div>
    </div>
</body>

方法2:
给要居中的块元素设置display:inline-block,再给其父元素设置text-align:center。原理:
没有宽度的块元素设置display:inline-block之后,其失去流体特性,宽度会由内在子元素撑开;然后将其视为行内元素的水平居中即可。
补充:
如果需要居中的元素是由数量不确定的文字撑开宽度的话,也可以给其设置display:inline;但如果是需要块元素撑开宽度的话,设置这个属性会失效,因为行内元素没有宽高属性,必须设置display:inline-block。所以这样看来,使用这个方法设置为display:inline-block更全面。
代码示例:

<style>
    .outer {
        width: 100%;
        /*实现内在行内元素水平居中*/
        text-align: center;
    }
    .father {
        border: 1px solid #376956;
        overflow: hidden;
        /*变为行内元素*/
        display: inline-block;
    }
    .son {
        width: 100px;
        height: 100px;
        background-color: #c3bed4;
        float: left;
        margin: 10px;
    }
</style>
<body>
    <div class="outer">
        <div class="father">
            <div class="son">我的数量不确定,意味着父元素不能设置固定宽度。</div>
            <div class="son">我的数量不确定,意味着父元素不能设置固定宽度。</div>
        </div>
    </div>
</body>

方法3:
要居中的元素加一个包裹层,设置float:left和position:relative、left:50%;然后要居中的元素设置position:relative、left:-50%即可。
补充:
设置为绝对定位也可以。
代码示例:

<style>
    .outer {
        /*设置这个之后,就会失去流体特性,然后把子元素包裹起来*/
        float: left;
        /*父元素相对定位向右偏移50%*/
        position: relative;
        left: 50%;
    }
    .father {
        border: 1px solid #376956;
        overflow: hidden;
        /*本身相对定位,然后相对父元素向左偏移50%*/
        position: relative;
        left: -50%;
    }
    .son {
        width: 100px;
        height: 100px;
        background-color: #c3bed4;
        float: left;
        margin: 10px;
    }
</style>
<body>
    <div class="outer">
        <div class="father">
        <div class="son">我的数量不确定,意味着父元素不能设置固定宽度。</div>
        <div class="son">我的数量不确定,意味着父元素不能设置固定宽度。</div>
    </div>
</body>

2 垂直居中

2.1 单行文本(父元素高度确定)

方法:
设置父元素的line-height = height即可。

2.2 多行文本(父元素高度确定)

Markdown

方法1:
块级元素(包含文本的父元素)设置display:table-cell,再设置vertical-aligh:middle即可。
代码示例:

<style>
    ul {
        height: 200px;
        background-color: #C3BED4;
        /*实现多行文本垂直居中*/
        display: table-cell;
        vertical-align: middle;
    }
</style>
<body>
    <ul>
        <li>我可以增加,只要不超过父元素的高度,都会垂直居中。</li>
        <li>我可以增加,只要不超过父元素的高度,都会垂直居中。</li>
    </ul>
</body>

方法2(flex):
要居中元素的父元素设置display:flex、flex-direction:column和justify-content:center,变为弹性盒子,然后改变主轴方向再居中即可。
代码示例:

<style>
    ul {
        height: 200px;
        background-color: #C3BED4;
        /*变为flex弹性盒子,实现多行文本垂直居中*/
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
</style>
<body>
    <ul>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod
    tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,
    quis nostrud exercitation ullamco
    </ul>
</body>

2.3 块元素(高度确定)

Markdown

方法:
要居中元素的父元素设置相对定位;自己设置绝对定位,top:50%(向下的位移是父元素高度的一半),margin设为自身高度一半的负值即可。。
代码示例:

<style>
    * {margin: 0;padding: 0;}
    ul,li{list-style:none;}
    ul {
        height: 200px;
        background-color: #C3BED4;

        position: relative;
    }
    li {
        height: 50px;
        background-color: #eeeeff;
        /*下面三行实现居中*/
        position: absolute;
        /*上的位移为父元素高度的一半。*/
        top: 50%;
        /*自己高度的一半。*/
        margin-top: -25px;
    }
</style>
<body>
    <ul>我是父元素
        <li>我是高度确定、需要垂直居中的块元素。
        </li>
    </ul>
</body>

2.4 块元素(高度不确定)

Markdown

方法1(transform):
要居中元素的父元素设置相对定位;自己设置绝对定位,top:50%(向下的位移是父元素高度的一半),transform:translateY(-50%)即可。
代码示例:

<style>
    * {margin: 0;padding: 0;}
    ul,li{list-style:none;}

    ul {
        height: 200px;
        background-color: #C3BED4;

        position: relative;
    }
    li {
        background-color: #eeeeff;

        position: absolute;
        top: 50%;
        transform: translateY(-50%);
    }
</style>
<body>
    <ul>
        <li>我是高度不确定、需要垂直居中的块元素。
        </li>
    </ul>
</body>

方法2(flex):
使父元素变为弹性盒子。父元素设置display:flex、flex-direction:column和justify-content:center,即可。
代码示例:

<style>
    * {margin: 0;padding: 0;}
    ul,li{list-style:none;}

    ul {
        height: 200px;
        background-color: #C3BED4;
        /*父元素变为弹性盒子,实现垂直居中。*/
        display: flex;
        flex-direction: column;
        justify-content: center;
    }
    li {
        background-color: #eeeeff;
    }
</style>
<body>
    <ul>
        <li>我是高度不确定、需要垂直居中的块元素。
        </li>
    </ul>
</body>

3 水平且垂直居中

3.1 块元素(宽高固定)

Markdown

方法1:
父元素设置相对定位;要居中的元素绝对定位,top和left值均为50%,然后margin值设为自身宽高一半的负值即可。
方法2:
父元素设置相对定位;要居中的元素绝对定位,四个方向的位移均设置为0,再margin:auto即可。
代码示例:

<style>
    * {margin: 0;padding: 0;}
    ul,li{list-style:none;}

    ul {
        height: 200px;
        background-color: #C3BED4;

        position: relative;
    }
    li {
        background-color: #eeeeff;
        width: 100px;
        height: 100px;
        /*实现绝对定位,重点是margin的应用。*/
        position: absolute;
        left: 0;
        top: 0;
        right: 0;
        bottom: 0;
        margin: auto;
    }
</style>
<body>
    <ul>
        <li>
        </li>
    </ul>
</body>

3.2 块元素(宽高不固定 )

Markdown

方法1(transform):
父元素设为相对定位;要居中的元素绝对定位,top和left值均设为50%,再设置transform:translate(-50%,-50%)即可。
补充:
使用 transform 有一个缺陷,就是当计算结果含有小数时(比如 0.5),会让整个元素看起来是模糊的,一种解决方案就是为父级元素设置 transform-style: preserve-3d。
代码示例:

<style>
    * {margin: 0;padding: 0;}
    ul,li{list-style:none;}

    ul {
        height: 200px;
        background-color: #C3BED4;

        position: relative;
    }
    li {
        background-color: #eeeeff;
        /*实现水平&垂直居中*/
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
    }
</style>
<body>
    <ul>
        <li>我是宽高不确定、需要水平垂直同时居中的块元素。
        </li>
    </ul>
</body>

方法2(flex):
要居中元素的父元素设置display:flex和justify-content:center和aligh-items:center即可。
代码示例:

<style>
    * {margin: 0;padding: 0;}
    ul,li{list-style:none;}

    ul {
        height: 200px;
        background-color: #C3BED4;
        /*父元素变为弹性盒子,实现垂直&水平居中。*/
        display: flex;
        justify-content: center;
        align-items: center;
    }
    li {
        background-color: #eeeeff;
    }
</style>
<body>
    <ul>
        <li>我是宽高不确定、需要水平垂直同时居中的块元素。
        </li>
    </ul>
</body>

结语

文章整理于自己的学习笔记,多为个人理解,仅供参考;如有真知灼见,欢迎交流。

文章始发于http://www.lipengcheng.xyz 如需转载,请注明出处,谢谢。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 210,914评论 6 490
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 89,935评论 2 383
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,531评论 0 345
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,309评论 1 282
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,381评论 5 384
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,730评论 1 289
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,882评论 3 404
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,643评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,095评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,448评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,566评论 1 339
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,253评论 4 328
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,829评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,715评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,945评论 1 264
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,248评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,440评论 2 348

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,734评论 1 92
  • 移动开发基本知识点 一.使用rem作为单位 html { font-size: 100px; } @media(m...
    横冲直撞666阅读 3,460评论 0 6
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 4,424评论 0 26
  • 收听音频,戳链接,旧号itclan已暂停使用,欢迎关注微信itclanCoder公众号可收听更多音频 前言 关于网...
    itclanCoder阅读 8,157评论 3 30
  • 1 var s = null; alert(typeof(s)) // object 2 jquer...
    浮生小孟阅读 181评论 1 0