css水平居中的各种方法总结(推荐)

啊,小雪,小雪,来了,来了。从微微的凉风中,从傍晚的喧闹中来了!像春风抖落万树梨花,像天女撒下漫天白絮……你不飘飘悠悠,因为那是骄傲的象征;你不轻轻起舞,因为那是胆小的缩影,听,沙沙沙沙、沙沙沙沙……我好像坐在屋里听那春雨的歌声。

但是,有时候会发现这样写了也没出效果。原因是什么呢? 请往下看。

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

行内元素:

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

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

XML/HTML Code复制内容到剪贴板
  1. <divstyle="text-align:center;border-style:solid">
  2. <pstyle="border-style:solid">我是块级元素,我不居中</p>
  3. <spanstyle="border-style:solid">我是行内元素,我要居中</span>
  4. </div>

效果如图:

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

XML/HTML Code复制内容到剪贴板
  1. <divstyle="text-align:center;border-style:solid">
  2. <pstyle="border-style:solid;width:500px">我是块级元素,我不居中</p>
  3. <spanstyle="border-style:solid">我是行内元素,我要居中</span>
  4. </div>

效果如图:

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

那么下面看块级元素居中。大家都知道块级元素是可以设置height和width的,那么这就又

分为定宽与不定宽。

定宽:

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

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

效果如图:

不定宽:

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

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

1、直接把元素改为行内元素,既display:inline,然后就可以用text-align:center了。但是这样width和height就不能设置了。

css:

CSS Code复制内容到剪贴板
  1. .container{
  2. text-align:center;
  3. }
  4. .containerul{
  5. list-style:none;
  6. padding:0;
  7. display:inline;
  8. }
  9. .containerli{
  10. margin-right:8px;
  11. border-style:solid;
  12. display:inline;
  13. }

body:

XML/HTML Code复制内容到剪贴板
  1. <divclass="container">
  2. <ul>
  3. <li><arel="nofollow noopener noreferrer" href="#">1</a></li>
  4. <li><arel="nofollow noopener noreferrer" href="#">2</a></li>
  5. <li><arel="nofollow noopener noreferrer" href="#">3</a></li>
  6. </ul>
  7. </div>

效果下:

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

整改后的css代码:

CSS Code复制内容到剪贴板
  1. .containerul{
  2. list-style:none;
  3. float:left;
  4. position:relative;left:50%;
  5. padding:0;
  6. }
  7. .containerli{
  8. margin-right:8px;
  9. float:left;
  10. position:relative;left:-50%;
  11. }

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

以上这篇css水平居中的各种方法总结(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。

原文地址:http://www.cnblogs.com/zuochengsi-9/archive/2016/06/02/5554340.html

您可能有感兴趣的文章
css让页脚保持在底部位置的四种方案

Flex布局史上最简单使用语法教程

新的CSS 伪类函数 :is() 和 :where()示例详解

纯CSS打字动画的如何实现示例

CSS浮动引起的高度塌陷问题