文字居中,文字垂直居中水平居中,图片居中,图片水平居中垂直居中,块元素垂直居中?当我们在做前端开发是时候关于css居中的问题是很常见的。情 况有很多种,不同的情况又有不同的解决方式。水平居中的方式解决的时候相对来说通过css比较容易设置,垂直居中相对比较棘手。
先来说一下水平居中的不同情况与不同解决方法吧。
1文本,图片等行内元素的水平居中方法呢比较简单。直接给父元素设置一个text-align:centent属性就可以实现元素的水平居中了。
2 确定宽度的块级元素水平居中怎么设置呢?设置方法也不难,可以通过设置外边距,margin:0 auto;这句来实现确定宽度的块级元素水平居中。
3 不确定宽度的块级元素设置水平居中的方法有多种,这里介绍三种方法给大家。
第一种方法呢,是使用table作为容器的方法来实现。当然不大推荐使用这种方法,因为添加了无意义的标签。这里就稍微介绍一下吧。Table标签本 身并不是块级元素,当我们不设置table的宽度的话,他里面的宽度是由他内部元素的宽度撑起来的。但即使我们没有设置table的宽度,直接设置 table的外边距margin:0 auto;就可以实现水平居中了!这样我们就可以通过设置table水平居中,间接使里面的内容居中。
第二种方法,相对于用table的方法的好处是不用增加无语义标签,简化标签嵌套深度。这个思路是这样的,通过改变块级元素的display属性值为 inline类型,然后设置text-align:center来实现居中。这种方法也有一定不妥之处就是把块级元素改为行内元素后,行内元素比块元素少 了一些功能。比如说设定长宽值等,在项目运用中可能会有一些限制,大家可以自行选择。
下面是第三种方法。通过给父元素设置浮动float,再设置父元素的position属性为relative和left:50%;子元素设置 position:relative和left:-50%来实现水平居中。这个好处是可以保留块级元素仍然是以display:block的形式显示,不 会添加无意义的标签,不添加嵌套深度。确点是设置了position:relative;带来了一些副作用。下面是第三种方法的实例代码,放到body标 签里面就可以了。
<div style=”400px;height:300px;background:#
333
;”>
<ul style=”margin:
0
auto;
float
:left; position:relative; left:
50
%;list-style:none; padding:
0
;”>
<li style=”position:relative; left:-
50
%;
float
:left”>OKOKOKOKKOOKK</li>
</ul>
</div>
三种方法使用都比较广泛,都有缺点和优点。具体选择哪种方法可视情况而定。Css文字图片块元素水平居中的方法就介绍到这里。