css点滴2—六种方式实现元素水平居中
本文参考文章《六种方式实现元素水平居中》
元素水平居中的方法,最常见的莫过于给元素一个显式的宽度,然后加上margin的左右值为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 a {
display: block;
color: #f2f2f2;
text-shadow: 1px 0 0 #101011;
padding: 0 10px;
border-radius: 2px;
box-shadow: 0 1px 0 #5a5b5c inset,0 1px 0 #080808;
background: linear-gradient(to top,#434345,#2f3032);
text-decoration: none;
}
.pagination a:hover {
text-decoration: none;
box-shadow: 0 1px 0 #f9bd71 inset,0 1px 0 #0a0a0a;
background: linear-gradient(to top,#f48b03,#c87100);
}
li {
list-style: none;
}
效果:

这显然不是我们想要的效果,接下来我们分几种方案来实现水平居中。下面css代码我们只贴出关键代码。
1.margin和width实现水平居中
第一种方式是最古老的实现方案,也是最常见的,在分页容器上定义一个宽度,然后配合margin的左右值为“auto”实现效果。
css代码:
.pagination li {
line-height: 25px;
list-style: none;
display: inline;
float: left;
margin: 0 5px;
}
/*!*给容器一个宽度*!*/
.pagination {
width: 500px;
margin-left: auto; /**/
margin-right: auto;
}
效果:

效果是实现了,但是扩展性不一定强。这种方式显示了5个分页和首页,末页共7个显示项,往往我们无法知道到底要显示多少个分页项,无法确定每个分页项的宽度是多少,也就无法确定容器的宽度。
缺点:这种方法简单易懂,浏览器兼容性强,但是扩展性差,需要确定容器宽度,无法自适应未知情况。
2.inline-block实现水平居中
这种方式使用inline-block和text-align:center结合起来实现水平居中。父标签设置text-align:center,文本居中,子组件设置display:inline-block,行内元素。
css代码:
.pagination{
text-align: center;
font-size:;
letter-spacing: -4px;
word-spacing: -4px;
}
.pagination li {
line-height: 25px;
margin: 0 5px;
display: inline-block;
*display: inline;
zoom:;
letter-spacing: normal;
word-spacing: normal;
font-size: 12px;
}
效果:

这种方法相对来说简单,但是使用inline-block实现了水平居中的问题,却又产生了一个新的问题,就是分页项之间的回车符带来的空白间距,这个间距也不是所有浏览器都会有,所以要解决下inline-block带来的间距,详细解决方法参考《如何解决inline-block元素的空白间距》
缺点:这种方法简单易懂,扩展性强,但是需要额外处理自组建中inline-block的空白间距。
3.浮动实现水平居中
float浮动要么考左,要么靠右,没有居中选项,其实只要略加处理就可以了。总体来说就是容器宽度100%,向右浮动50%,子元素向左浮动50%,并且都相对定位。
css代码:
.pagination {
float: left; /*分页容器浮动到左边*/
width: 100%; /*分页容器宽度为100%*/
overflow: hidden;
position: relative; /*相对正常位置定位*/
}
.pagination ul {
clear: left;
float: left; /*内部容器浮动到左边*/
position: relative; /*相对正常位置定位*/
left: 50%; /* 整个内部容器向右边移动宽度的50% */
text-align: center;
}
.pagination li {
line-height: 25px;
margin: 0 5px;
display: block;
float: left; /*每个分页也浮动到左边*/
position: relative; /*相对正常位置定位*/
right: 50%; /* 每个分页项向左移动宽度的50% */
}
效果:

这种方法和前面的都不同,使用浮动float配合position:relative相对自身定位来实现,下面的文章介绍了这种方法的实现原理《Horizontally Centered Menus with no CSS hacks》
div是一个块元素,其默认宽度是100%,如图所示:
如果给div设置了浮动之后,他的内容有多宽就会撑开多大的容器(除显式设置元素宽度值之外),这也是让分页导航居中的关键:
接下来使用传统的制作方法,让导航浮动到左边,而且每个分页也进行浮动
现在要想的办法是让分页导航居中的效果,这里是通过“position:relative”属性实现,首先在列表项ul上向右移动50%(left:50%),如下图:
如上图一样整个分页容器向右移动了50%的距离,接着我们在“li”上也定义“position:relative”属性,但其移动方向和列表“ul”移动方向刚好相反,而且移动值保持一致,也是50%:
这样就实现了float浮动居中的效果。
缺点:这种方式实现的兼容性强,扩展性强,但是实现原理比较复杂。
4.绝对定位实现水平居中
绝对定位实现水平居中,元素绝对定位:“position:absolute;”,向右移动50%:“left:50%;” ,设置固定宽度:“width:宽度值;”,设置左外边距为宽度值的一半:“margin-left:-(宽度值/2);”,代码如下:
.ele {
position: absolute;
width: 宽度值;
left: 50%;
margin-left: -(宽度值/2);
}
但是这种做法有一个缺点,大多数情况下我们不知道元素的宽度,或者元素宽度是不固定的,但是我们可以在第三种方法的基础上做一点变通:容器绝对定位,左偏移50%,子元素相对定位,右浮动,右偏移50%
css代码:
.pagination {
position: relative; /*div相对定位*/
}
.pagination ul {
position: absolute; /*分页容器绝对定位*/
left: 50%; /*分页容器向右移动50%*/
}
.pagination li {
line-height: 25px;
margin: 0 5px;
position: relative; /*分页元素相对定位,注意这里不是absolute*/
float: left; /*分页元素浮动在右边*/
right: 50%; /*分页元素向左移动50%*/
}
效果:
缺点:这种方式扩展性强,兼容性强,但是理解起来比较难。
5.css3的flex实现水平居中
css3的flex是一个很强大的功能,能让布局变得灵活方便,唯一的缺点就是目前兼容性差。父元素flux布局,box-pack:center,box-origt:center,横向排列。
css代码:
.pagination{
display: -webkit-box;
-webkit-box-orient: horizontal;
-webkit-box-pack: center;
display: -moz-box;
-moz-box-orient: horizontal;
-moz-box-pack: center;
display: -o-box;
-o-box-orient: horizontal;
-o-box-pack: center;
display: -ms-box;
-ms-box-orient: horizontal;
-ms-box-pack: center;
display: box;
box-orient: horizontal;
box-pack: center;
}
.pagination li {
line-height: 25px;
margin: 0 5px;
float: left;
}
效果:

缺点:这种方法实现起来比较便捷,扩展性强,但是兼容性比较差。
6.css3的fit-content实现水平居中
这种实现居中的方法参考《Horizontal centering using CSS fit-content value》。“fit-content”是给css的“width”属性增加一个with:fit-content,表示缩小到内容宽度,再配合margin:auto可以轻松的实现水平居中的效果。
.pagination ul {
width: -moz-fit-content;
width: -webkit-fit-content;
width: fit-content; /*给with属性值设置为fit-content*/
margin: 0 auto;
}
.pagination li {
line-height: 25px;
margin: 0 5px;
float: left;
}
效果:

缺点:这种方式简单易懂,扩展性强,缺点是兼容性差。
css点滴2—六种方式实现元素水平居中的更多相关文章
- css点滴1—八种方式实现元素垂直居中
这里介绍实现元素垂直居中的方式,文章是参考了<css制作水平垂直居中对齐>这一篇文章. 1.行高和高度实现 这种方式实现单行垂直居中是很简单的,但是要保证元素内容是单行的,并且其高度是不变 ...
- 【css系列】六种实现元素水平居中方法
一.前言 居中效果在CSS中很是普通的效果,平时大家所看到的居中效果主要分为三大类:水平居中.垂直居中和水平垂直居中.而其中水平居中相对于后两者来说要简单得多.使用了css3的flexbox的属性轻松 ...
- CSS/CSS3 如何实现元素水平居中
更新:可直接访问 [CSS/CSS3 如何实现元素水平居中] 查看效果,右键查看源代码 -------------------------------------------------分割线---- ...
- CSS布局:元素水平居中
CSS布局之元素水平居中 本文将依次介绍在不同条件下实现水平居中多种方法 一.使用 text-align: center : 适用于块级元素内部的行内元素水平居中(也适用于图片的水平居中) 此方法对i ...
- css确定元素水平居中和垂直居中
---恢复内容开始--- 首先,我们在了解如何通过css了解元素水平和垂直居中之前,先要了解下html都有哪些元素,这些元素与偶有哪些分类,因为不同类别的元素的水平垂直居中方法是完全不同的,究其根本当 ...
- css让浮动元素水平居中
对于定宽的非浮动元素我们可以用 margin:0 auto; 进行水平居中. 对于不定宽的浮动元素我们也有一个常用的技巧解决它的水平居中问题.如下: HTML 代码: <div class=&q ...
- 经典CSS坑:如何完美实现垂直水平居中?
经典CSS坑:如何完美实现垂直水平居中? 踩了各种坑之后总结出的方法,开门见山,直接上代码和效果图.希望对读者有所帮助,后续如果有更好的方法,我也会持续更新 第一种方法:transform(个人认为最 ...
- CSS实现水平垂直居中方式
1.定位 核心代码实现请看示例代码中的注释: <!DOCTYPE html> <html lang="zh"> <head> <meta ...
- HTML中放置CSS的三种方式和CSS选择器
(一)在HTML中使用CSS样式的方式一般有三种: 1 内联引用 2 内部引用 3 外部引用. 第一种:内联引用(也叫行内引用) 就是把CSS样式直接作用在HTML标签中. <p style ...
随机推荐
- 使用 Mutex 实现进程间同步
我们知道 Mutex 互斥量是可以用在线程间同步的,线程之间共享进程的数据,mutex 就可以直接引用.而进程有自己独立的内存空间,要怎样将它应用在进程间同步呢?为了达到这一目的,可以在 pthrea ...
- 分布式系统监视zabbix讲解四之可视化--技术流ken
图形 概述 随着大量的监控数据被采集到Zabbix中,如果用户可以以可视化的表现形式来查看发生了什么事情,那么和仅仅只有数字的表现形式比起来则更加轻松. 以下是进行图形设置的地方.图形可以一目了然地掌 ...
- 怎样监听vue.js中v-for全部渲染完成?
vue里面本身带有两个回调函数: 一个是Vue.nextTick(callback),当数据发生变化,更新后执行回调. 另一个是Vue.$nextTick(callback),当dom发生变化,更新后 ...
- RNN-LSTM入门
RNN-LSTM入门 Last Edited: Dec 02, 2018 10:20 PM Tags: 机器学习,论文阅读 RNN-Recurrent Neural Network 概念: 序列数据: ...
- C# 给一个控件去掉焦点
给一个控件去掉焦点(如选中控件按钮button时,按钮出现方框显示):例如给form这个窗体中的button按钮去焦点1.首先在form这个窗体中拖一个label按钮,去文字,设置背景为透明: 2.然 ...
- [nodejs] nodejs开发个人博客(二)入口文件
错误处理中间件 定义错误处理中间件必须使用4个参数,否则会被作为普通中间件 /*错误处理器*/ application.use(function(err,req,res,next){ console. ...
- Netty实战七之EventLoop和线程模型
简单地说,线程模型指定了操作系统.编程语言.框架或者应用程序的上下文中的线程管理的关键方面.Netty的线程模型强大但又易用,并且和Netty的一贯宗旨一样,旨在简化你的应用程序代码,同时最大限度地提 ...
- 汇编语言--微机CPU的指令系统(五)(位操作指令)
(6) 位操作指令 1.位扫描指令(Bit Scan Instruction) 指令的格式:BSF/BSR Reg, Reg/Mem ;80386+ 受影响的标志位:ZF 位扫描指令是在第二个操作数中 ...
- LNMP环境下安装Redis,以及php的redis扩展
1.下载 sudo wget http://download.redis.io/releases/redis-4.0.9.tar.gz 2.解压 sudo tar zvxf redis-4.0.9.t ...
- 1:Python开发:初识Python
1.开发语言: 高级语言:Python, Java, PHP ,C# ,Go, ruby, c++ ==>字节码 低级语言:C,汇编 ==>机器码 2.开发语言的对比: PHP类:适用于写 ...