css水平居中的各类方法

说到水平居中,你们可能以为很简单啊,text-align:center 就OK了。css

可是,有时候会发现这样写了也没出效果。缘由是什么呢?  请往下看。html

水平居中:分为块级元素居中和行元素居中web

 

行内元素:spa

行内元素就是内联元素。例如<span>、<a>、<label>、<em>、<img>等。。code

直接构建一个具备 ”text-align:center“样式的容器,那么里面包含的行内元素就会都居中了。orm

 <div style="text-align:center;border-style:solid">
        <p style="border-style:solid">我是块级元素,我不居中</p>
        <span style="border-style:solid">我是行内元素,我要居中</span>
    </div>

效果如图:htm

有没有发现不对,块级元素怎么“看起来”也居中了?给<p>加上宽度后:blog

 <div style="text-align:center;border-style:solid">
        <p style="border-style:solid;width:500px">我是块级元素,我不居中</p>
        <span style="border-style:solid">我是行内元素,我要居中</span>
    </div>

效果如图:get

原来只是里面的文本居中了!it

 

 

块级元素:

块级元素有:div  , p  , form,   ul,  li ,  ol, dl,    form,   address,  fieldset,  hr, menu,  table

你们都知道块级元素是能够设置height和width的,那么这就又

分为定宽与不定宽。

定宽:

定宽其实很好解决。直接margin:0 auto就能够实现容器居中,再加上text-align:center才可让文本居中。

    <p style="border-style:solid;text-align:center;margin:0 auto;width:500px">我是定宽块级元素,我要居中</p>

效果如图:

 

不定宽:

不定宽实际上是用的最多的,如这种导航栏:

由于导航栏中的内容是会变化的,因此宽度就不能定死了。要居中的话有三种方法,其中一种是利用table标签的特性,感受适用性不是很好就不介绍了。

一、直接把元素改成行内元素,既display:inline,而后就能够用text-align:center了。可是这样width和height就不能设置了。

css:

  .container{
    text-align:center;
}
.container ul{
    list-style:none;
    padding:0;
    display:inline;
}
.container li{
    margin-right:8px;
    border-style: solid;
display:inline; }

body:

<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>

效果下:

二、下面使用父级元素浮动和相对定位以及lelf:50%。子元素照样设置但left:-50%。

整改后的css代码:


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

效果是同样的,就不贴图了。(首先,ul设置左浮动是为了 使得ul的宽度不是100%,而是 几个li宽度的总和。 以后ul相对定位 使用left把ul移动到剧中位置。由于相对定位是以原来的位置为原点的,因此先总体移动中间,这样子ul元素的左边是中心线,那么里面ul里面的li只要left:-50% 或者right:50%就居中了)

关于浮动能够参考这篇文章http://www.th7.cn/web/html-css/201401/17089.shtml

 CSS3新特性实现起来更方便:http://www.cnblogs.com/zuochengsi-9/p/7659489.html

相关文章
相关标签/搜索