CSS设置水平居中和垂直居中

1.行内元素设置水平居中
通过设置父元素

text-align:center

2.定宽块状元素设置水平居中
通过设置“左右margin”值为“auto”来实现居中的。

width:500px;/*定宽*/
margin:0px auto;/* margin-left 与 margin-right 设置为 auto */

3.不定宽块状元素设置水平居中
(1)为需要设置的居中的元素外面加入一个 table 标签;这个table的CSS样式设置为“左右 margin”的值为auto

<tbody><tr><td>
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</td></tr></tbody>
table{
    margin:0 auto;
}
(2)改变块级元素的 dispaly 为 inline 类型,然后使用 text-align:center 来实现居中效果
<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
.container{
    text-align:center;
}
.container ul{
    list-style:none;
    display:inline;
}
.container li{
    margin-right:8px;
    display:inline;
}

(3)通过给父元素设置 float,然后给父元素设置 position:relative 和 left:50%; 子元素设置 position:relative 和 left:-50% 来实现水平居中。

<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
.container{
    position:relative;
    left:50%
}

.container ul{
    list-style:none;
    position:relative;
    left:-50%;
}
.container li{
    float:left;
    display:inline;
    margin-right:8px;
}    

4.父元素高度确定的单行文本垂直居中
通过设置父元素的 height 和 line-height 高度一致来实现

<div class="container">
    hi,imooc!
</div>
.container{
    height:100px;
    line-height:100px;
}

5.父元素高度确定的多行文本垂直居中

(1)使用插入 table (包括tbody、tr、td)标签,同时设置 vertical-align:middle

<table><tbody><tr><td class="wrap">
    <div>
        <p>看我是否可以居中。</p>
        <p>看我是否可以居中。</p>
    </div>
</td></tr></tbody></table>
    td 标签默认情况下就默认设置了 vertical-alignmiddle

(2)设置块级元素的 display 为 table-cell,设置 vertical-align 属性

<div class="container">
    <div>
        <p>看我是否可以居中。</p>
        <p>看我是否可以居中。</p>
    </div>
</div>
.container{
    display:table-cell;/*IE8以上及Chrome、Firefox*/
    vertical-align:middle;/*IE8以上及Chrome、Firefox*/
}

以上技巧和代码整理致 imooc

http://www.imooc.com/learn/9

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值