CSS水平居中的四种方法

水平垂直居中,特别是使用在列表的时候经常会用到的,以前有需求的时候我也做过类似的代码,是使用display:table-cell,mg12的博客那个相关文章的列表好像就是使用这个代码来的,之前我也是参考他来的。
今天重新整理一下,并结合前人的辛劳,总结一下以作备份。 水平居中,如果知道元素的宽度,则可以使用 .cell{width:300px; margin:0 auto; text-align:center;}如果是内联元素居中,那么直接用text-align:center则行 如果未知元素宽度,并且非内联元素,那么下面给出的几种方案也适合你。

第一种:相对定位法

原理是父类浮动的同时向左left:50%,而子类则向左浮动的同时left:50%;

<style type="text/css">.centerlist {position:relative;left:50%;float:left;}.centerlist li {position:relative;right:50%; z-index:2;float:left}</style><ul class="centerlist"> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li> <li><a href="#">Lorem ipsum dolor.</a></li></ul>

第二种:强制内联

<style type="text/css">.centerlist_inline{text-align: center;}.centerlist_inline li{display: inline;}</style><ul class="centerlist_inline"><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li></ul>

局限:块级元素改为内联元素,那么高度、宽度、margin-top,margin-bottom, padding-top,padding-bottom,等都不能用。

第三种: 使用inline-block

如果大家看过我之前写的inline-block替换float可能就会清楚这个属性的好处了。

<style type="text/css">.centerlist_inline-block{text-align: center; font-size:0; -letter-spacing:-1px;}.centerlist_inline-block li{display: inline-block; \*display: inline; \*zoom:1; font-size:12px; letter-spacing:normal; word-spacing:normal;}</style><ul><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li></ul>

第四种:table-cell

<style type="text/css">.centerlist_table-cell{display:table; margin:0 auto;}.centerlist_table-cell{display:table-cell;}</style><ul class="centerlist_table-cell"><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li><li><a href="">lorem1</a></li></ul>

缺点是不兼容ie6,ie7 推荐使用inline-block这种水平居中的方法,既保留了块级元素特性,而且完美兼容。就是代码有点多。

另外你还可以使用表格的方式来水平居中。 说完了水平居中,下面说垂直居中。如果元素是内联元素,并且只有一行,则我们可以通过line-height来设置与其高度同样大小,则实现了垂直居中了。

最后

关注公众号:前端开发博客,并回复:1024, 领取前端进阶资料包

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值