一、前言

居中效果在CSS中很是普通的效果,平时大家所看到的居中效果主要分为三大类:水平居中、垂直居中和水平垂直居中。而其中水平居中相对于后两者来说要简单得多。使用了css3的flexbox的属性轻松实现多行文本水平垂直居中的方法。当然大家有可能认为这些方法对于浏览嘎嘎的兼容性处理太麻烦了。

二、六种方法

常见的居中是固定宽度,加上margin: 0 auto。但是如果宽度不明确,我们也要尝试一下。

我们来实现一个分页容器

html

<div class="pagination">
<ul>
<li><a href="#">Prev</a></li>
<li><a href="#">1</a></li>
<li><a href="#">2</a></li>
<li><a href="#">3</a></li>
<li><a href="#">4</a></li>
<li><a href="#">5</a></li>
<li><a href="#">Next</a></li>
</ul>
</div>

css

.pagination li{
line-height: 25px;
list-style: none;
display: inline;
float: left;
}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

展示:

 

1、方法一:margin和width实现

这个是最常见的方案:在容器上定义一个固定的宽度,然后配合margin左右的值为auto。

css

.pagination{
width: 340px;
margin: 0 auto;

}
.pagination li{
line-height: 25px;
list-style: none;
display: inline;
float: left;
}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

展示

效果实现了,扩展性不强,因为宽度无法确定,也就无法确定容器宽度。

优点:实现简单,浏览器兼容性强

缺点:扩展性差,无法自适应未知情况。

2、方法二:inline-block和父元素text-align

仅inline-block属性是无法让元素水平居中,他的关键之处要在元素的父容器中设置text-align的属性为“center”,这样才能达到效果:

body{
background: #000;
text-align: center;
}
.pagination{
margin-top: 50px;
display: inline-block;
}
.pagination li{
line-height: 25px;
list-style: none;
display: inline;
float: left;
}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

显示

这个方法也是比较简单易懂,inline-block解决了水平居中的问题,但是又有一个新的问题--空白间距,所以需要解决inline-block带来的间距。

优点:简单易懂,扩展性强

缺点:需要额外处理inline-block的浏览器兼容性问题

3、方法三:浮动实现水平居中

感到很意外,元素都浮动了,他还能水平居中?大家都知道,浮动要么靠左、要么靠右,还真少见有居中的。其实略加处理就有了。

body{
background: #000;
}
.pagination{
margin-top: 50px;
float: left;
width: 100%;

}
.pagination ul{
position: relative;
float: left;
left: 50%;

}
.pagination li{
line-height: 25px;
list-style: none;
display: inline;float: left;
position: relative;
right: 50%;

}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

展示:

没有浮动的div:大家都知道div是一个块元素,其默认的宽度就是100%,如图所示:

如果div设置了浮动之后,他的内容有多宽度就会撑开有多大的容器(除显式设置元素宽度值之外),这也是我们实现让分页导航居中的关键所在:

接下来使用传统的制作方法,我们会让导航浮动到左边,而且每个分页项也进行浮动,就如下图所示一样:

现在要想的办法是让分页导航居中的效果了,在这里是通过“position:relative”属性实现,首先在列表项“ul”上向右移动50%(left:50%;),看到如下图所示:

整个分页向右移动了50%的距离,紧接着我们在“li”上也定义“position:relative”属性,但其移动的方向和列表“ul”移动的方向刚好是反方向,而其移动的值保持一致:

这样一来就实现了float浮动居中的效果。

优点:兼容性强,扩展性强。

缺点:实现原理比较复杂

4、方法四:绝对定位实现

绝对定位实现水平居中,我想大家也非常的熟悉了,并且用得一定不少。

.ele {
position: absolute;
width: 宽度值;
left: 50%;
margin-left: -(宽度值/2);
}

但这种实现我们有一个难题,我并不知道元素的宽度是多少,这样也就存在如方法一所说的难题,但我们可以借助方法三做一点变通:

body{
background: #000;
margin-top: 50px;
}
.pagination ul{
position: absolute;
left: 50%;

}
.pagination li{
line-height: 25px;
list-style: none;
display: inline;
float: left;
position: relative;
right: 50%;

}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

展示:

优点:扩展性强,兼容性强;

缺点:理解性难。

5、方法五:css3的flex实现

能让我们的布局变得更加灵活与方便,唯一的就是目前浏览器的兼容性较差。那么第五种方法,我们就使用flex来实现。

body{
background: #000;
margin-top: 50px;
}
.pagination{
display: flex;
justify-content: center;

}
.pagination li{
line-height: 25px;
list-style: none;
display: inline;
float: left;
}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

展示:

优点:实现简单,扩展性强

缺点:兼容性差

6、方法六:css3的fit-content

“fit-content”是CSS中给“width”属性新加的一个属性值,他配合margin可以让我轻松的实现水平居中的效果:

body{
background: #000;
margin-top: 50px;
}
.pagination{
width: fit-content;
margin: 0 auto;

}
.pagination li{
line-height: 25px;
list-style: none;
display: inline;
float: left;
}
.pagination a{
text-decoration: none;
display: block;
color: #000;
padding: 0 10px;
border-radius: 2px;
border: 1px solid #F2F2F2;
background: #333;
}
.pagination a:hover{
background: orange;
}

展示:

优点:简单易懂,扩展性强

缺点:浏览器兼容性差

三、参考

1、http://www.w3cplus.com/css/elements-horizontally-center-with-css.html

【css系列】六种实现元素水平居中方法的更多相关文章

  1. <转载>使CSS文字图片div元素居中方法之水平居中的几个方法

    文字居中,文字垂直居中水平居中,图片居中,图片水平居中垂直居中,块元素垂直居中?当我们在做前端开发是时候关于css居中的问题是很常见的.情 况有很多种,不同的情况又有不同的解决方式.水平居中的方式解决 ...

  2. CSS/CSS3 如何实现元素水平居中

    更新:可直接访问 [CSS/CSS3 如何实现元素水平居中] 查看效果,右键查看源代码 -------------------------------------------------分割线---- ...

  3. css点滴2—六种方式实现元素水平居中

    本文参考文章<六种方式实现元素水平居中> 元素水平居中的方法,最常见的莫过于给元素一个显式的宽度,然后加上margin的左右值为auto.这种方式给固定宽度的元素设置居中是最方便不过的.但 ...

  4. 深入理解脚本化CSS系列第六篇——脚本化伪元素的6种方法

    × 目录 [1]动态样式 [2]CSS类[3]setAttribute()[4]CSSRule对象添加[5]空样式覆盖[6]CSSRule对象删除 前面的话 我们可以通过计算样式来读取伪元素的样式信息 ...

  5. CSS中元素水平居中和垂直居中的方法

    #CSS中水平居中和垂直居中的方法 一. 水平居中 1.行内元素(文本,图片等) 如果被设置元素为文本.图片等行内元素时,可以通过给父元素设置` text-align:center;` 来实现 2.定 ...

  6. 顽石系列:CSS实现垂直居中的五种方法

    顽石系列:CSS实现垂直居中的五种方法 在开发过程中,我们可能沿用或者试探性地去使用某种方法实现元素居中,但是对各种居中方法的以及使用场景很不清晰.参考的内容链接大概如下: 行内元素:https:// ...

  7. css确定元素水平居中和垂直居中

    ---恢复内容开始--- 首先,我们在了解如何通过css了解元素水平和垂直居中之前,先要了解下html都有哪些元素,这些元素与偶有哪些分类,因为不同类别的元素的水平垂直居中方法是完全不同的,究其根本当 ...

  8. CSS元素垂直居中方法总结

    坚持,坚持,坚持... 以上为自我鼓励,哈哈... ------------------------------------------------- 相信没有真正是尝试过的人应该都和我一样,觉得居中 ...

  9. CSS布局:元素水平居中

    CSS布局之元素水平居中 本文将依次介绍在不同条件下实现水平居中多种方法 一.使用 text-align: center : 适用于块级元素内部的行内元素水平居中(也适用于图片的水平居中) 此方法对i ...

随机推荐

  1. 长江存储32层3D NAND今年底准备好,预计2020年赶上世界前沿(有些ppt很精彩)

    集微网消息(文/刘洋)2017年1月14日,首届IC咖啡国际智慧科技产业峰会暨ICTech Summit 2017在上海隆重举行.本次峰会以“匠心独运 卓越创‘芯’”为主题,集结了ICT产业领袖与行业 ...

  2. 由TreeView 如何触发OnSelectedNodeChanged事件想到的与做到的

    前提是每层的结点上设置了NavigateUrl OnSelectedNodeChanged事件好像失去了作用. 另外TreeView是没有AutoPostBack的!!!! 那么要如何触发OnSele ...

  3. WebP 大战 JPEG,谁才是真正的王者?

    目前在互联网上,图片流量仍占据较大的一部分.因此,在保证图片质量不变的情况下,节省流量带宽是大家一直需要去解决的问题.传统的图片格式,如 JPEG,PNG,GIF 等格式图片已经没有太多的优化空间.因 ...

  4. vuejs切换导航条高亮路由高亮做法

    我的GitHub前端经验总结,喜欢的话请点star✨✨Thanks.:https://github.com/liangfengbo/frontend-develop vuejs导航条高亮我的做法: 用 ...

  5. win7 docker安装文件及安装问题

    最近在玩爬虫,需要装docker,但是官网对于win7版本,只支持docker tool box,在官网找了半天才找到安装包,特此上传百度网盘,方便各位下载 链接:https://pan.baidu. ...

  6. windows pyspider WEB显示框太小解决方法

    环境:windows7 + chrome + pyspider 解决方法: WEB预览框过小的原因在于页面元素的css属性height被替换为60px: CSS文件所在地方:C:\Users\Admi ...

  7. Redis 学习笔记(篇三):跳表

    跳表 跳表(skiplist)是一种有序的数据结构,是在有序链表的基础上发展起来的. 在 Redis 中跳表是有序集合(sort set)的底层实现之一. 说到 Redis 中的有序集合,是不是和 J ...

  8. golang开发:类库篇(一) Zap高性能日志类库的使用

    为什么要用zap来写日志 原来是写PHP的,一直用的error_log,第一次写Go项目的时候,还真不知道该怎么写日志,后来就按照PHP的写法自己不成规范的捣鼓写.去了新公司之后,发现用的是zap.后 ...

  9. docker search/pull 报错

    docker报错 Get https://registry-1.docker.io/v2/: x509: certificate has expired or is not yet valid 这种错 ...

  10. shell遍历文件

    取文件每行的数据,需要按列取  可以 sed 加管道 使用 awk 取列 platform="list.txt" line=`grep -vc '^$' $platform` ; ...