CSS居中的常用方式以及优缺点
前言
居中是页面开发中经常遇到的问题。
使用合适的、简单的、兼容性好的居中方式是我们页面仔在整个工作生涯中都要面对的问题。
text-align:center
来看这个例子,一张图片和文字进行居中。如下图所示:

img
与文字内容都是行内元素,因此直接使用text-align
就行了。代码如下图所示:

在最外层的div
中使用text-align:center
的问题是,会导致所有的子元素都会继承这个属性。如果还有一段文字用作介绍该图片的作用时,这段文字也会被居中。

而我们希望这段文字是左对齐的,就不得不单独设置其text-align:left
属性,以覆盖其父元素的属性。并且如果还有更多的子元素也需要这样做,覆盖属性本身就是下策,因此要采用其他方法。
margin: 0 auto
由于显示的图片可能是变化的,宽高是不定的,但显示区域是固定的,所以一般会显式地给图片设置一个宽高。这个时候知道宽度就可以设置margin:0 auto
方法,左右的margin
设置为auto
,浏览器就会自动设置左右的margin
值为容器剩余宽度的一半。

使用margin: 0 auto
可以说是最常用的左右居中的方法,不仅适用于块级元素也适用于行内元素。很多网页的布局都是使用margin: 0 auto
,例如淘宝pc端,如下图所示:

display: table-cell
第一个垂直居中的方法是借助table-cell
属性,效果图如下:

table-cell
的一个好处就是它可以兼容到IE8
。
table-cell
属性的缺点:
- 容器的
margin
属性失效,因为margin
不适用于表格布局。所以使用margin: 0 auto
属性是不能使container
左右居中的。解决的方法也很简单:只需要在container
外层再多套一个div容器,然后设置这个外层容器的margin: 0 auto
即可。 - 设置了
table-cell
的元素再设置宽高为百分比是不起作用的。常见的场景是要将宽度属性设置为外层容器宽度的100%,解决方法是将container
的宽度设置成一个很大的值,例如5000px
,这样就达到100%的目的。 - 如果
container
需要设置position
为absolute
,table-cell
属性就会失效。因为设置position: absolute
就会把元素display
强制设置为block
类型。解决办法还是在外层套一层div
容器,将position: absolute
属性作用于这个容器上。
position: relative
上面所说table-cell
的第三缺点的解决方法有一个副作用,就是设置内层container
的height
和width
为百分比时会失效。由于这个原因,导致有一种情况不能使用display:table-cell
垂直居中。
就是需要在页面弹出一个框,这个框的位置需要在当前屏幕中左右上下居中。这时候通常需要将这个框的position
设置为absolute
,这个时候table-cell
就不能发挥作用了。
解决办法是使用relative
定位,设置top
为50%,将弹窗的起始位置放到页面中间,再设置margin-top
为元素高度的负一半,这样使得弹窗在页面中间位置再往上移到一半自身的高度,这就正好在中间了,左右居中也可类似处理。

使用此方法的缺点是需要知道具体的高度,无法根据内容长短自适应。
tranform: translate
用tranform
方法,将margin-top
一个具体像素的负值改成transform: translate(0, -50%)
,因为translate
里面的百分比是根据元素本身的高度计算的,所以就可以达到自适应的效果。

这个办法十分方便,而且加上-webkit-
前缀,可以兼容到IE9。
而margin-top:-100px
与transform:translate(0, -50%)
都有一个缺点,就是如果设置left
为50%是借助position
为absolute
的话,可能会导致换行

本来应该是一行显式的p
元素却换行了,这是因为在一个relative
元素里面的absolute
定位的子元素会通过行内元素换行的方式,尽可能不超过容器的边界。由于设置left
为50%,导致p
元素超了边界,所以就换行了,即使再设置translate:-50%
也已经晚了。
flex布局
flex
布局十分容器和方便,只需在副容器设置3个属性就行了
.container{
display: flex;
align-items: center;
justify-content: center;
}
但flex
的缺点是不支持IE
vertical-aligin:middle
vertical-aligin:middle
主要是运用在行内元素中的。

如果不做任何处理,那么默认的垂直居中是以baseline
为基准的。
为了能够垂直居中,需要改变居中方式。

要每个元素都要设置。
如果container
的高度比图片要高,就会有留空的效果,如下:

为了让中间的内容能够在container
里上下居中,可以设置文字的line-height
为container
的高度,这样文字就上下居中了。由于图片与文字是垂直居中的,所以图片在container
里也是上下居中了。

也就是说,如果需要垂直居中一个div
里的比div
高度小的图片,可以添加一个元素,让它的line-height
等于div
的高度。下面使用伪元素::before
来添加line-height
。

或者使用display: inline-block
属性,加上height: 100%
。这个方法兼容性更好。

absolute与margin:auto
使用absolute
定位与margin:auto
方法也可以实现居中。

如果图片比container
大,这种方法就不适用了。因为有一个种比较常见的场景:图片有一边和contianer
一样大,另一边按图片的比例缩放,图片居中显示,超出的截断。这种情况下,只需把left/right/top/bottom
设置为一个很大的负值即可。

总结
以上就是css
中常用的居中方法,如果有更好的方法评论区留言讨论。
作者: zhangwinwin
链接:CSS居中的常用方式以及优缺点
来源:github
CSS居中的常用方式以及优缺点的更多相关文章
- 我已经说了5种css居中实现的方式了,面试官竟然说还不够?
这是一篇关于居中对齐方式的总结 开篇之前,先问一下大家都知道几种居中的实现方式? 面试时答出来两三个就不错了,就怕面试官还让你继续说.今天就来总结一下这些居中的方式 使用flex布局设置居中. 使用f ...
- 常用的CSS居中方式
1.水平居中margin 0 auto;(浮动元素除外) 这个属性在网页制作的过程中是经常被用到的,一般情况下页面的版心你就可以看到它. <style> .father { width: ...
- 各种div+css居中方式调整(转载)
盘点8种CSS实现垂直居中水平居中的绝对定位居中技术 分类: 前端开发2013-09-11 21:06 24959人阅读 评论(3) 收藏 举报 绝对居中垂直居中水平居中CSS居中代码 目录(?) ...
- 【基础】这15种CSS居中的方式,你都用过哪几种?
简言 CSS居中是前端工程师经常要面对的问题,也是基本技能之一.今天有时间把CSS居中的方案汇编整理了一下,目前包括水平居中,垂直居中及水平垂直居中方案共15种.如有漏掉的,还会陆续的补充进来,算做是 ...
- 第212天:15种CSS居中的方式,最全了
CSS居中是前端工程师经常要面对的问题,也是基本技能之一.今天有时间把CSS居中的方案整理了一下,目前包括水平居中,垂直居中及水平垂直居中方案共15种.如有漏掉的,还会陆续的补充进来,算做是一个备忘录 ...
- CSS属性(常用的属性)
CSS属性(常用的属性)http://www.w3school.com.cn/cssref/index.asp 一:文本与字体属性 1.字体属性 (1):font-size:字体的大小(例如:font ...
- css居中小结
从css入门就开始接触,无所不在的,一直备受争议的居中问题. css居中分为水平居中和垂直居中,水平居中方式也较为常见和统一,垂直居中的方法就千奇百怪了. 博客原文地址:Claiyre的个人博客 ht ...
- vue—你必须知道的 js数据类型 前端学习 CSS 居中 事件委托和this 让js调试更简单—console AMD && CMD 模式识别课程笔记(一) web攻击 web安全之XSS JSONP && CORS css 定位 react小结
vue—你必须知道的 目录 更多总结 猛戳这里 属性与方法 语法 计算属性 特殊属性 vue 样式绑定 vue事件处理器 表单控件绑定 父子组件通信 过渡效果 vue经验总结 javascript ...
- css两种常用的不定宽高的水平垂直居中方法,记住它,不再为样式发愁
css 几种常用的简单容易记住的水平垂直居中方法 前言 正文 第一种方法 第二种方法 结束语 前言 我们在设计网页时,会大量的运用到水平垂直居中,如果知道元素的宽高,那水平垂直居中是很简单的,无非是用 ...
随机推荐
- DX关联VS
// Windows API: #include <windows.h> // C 运行时头文件,测试可能会用到 #include <stdlib.h> //standa ...
- PDO实用
$sql="select * from test4 "; $b = $pdo->query($sql); // 返回的是个新对象 $c =$b->fetchAll(); ...
- 215. Kth Largest Element in an Array找出数组中第k大的值
堆排序做的,没有全部排序,找到第k个就结束 public int findKthLargest(int[] nums, int k) { int num = 0; if (nums.length &l ...
- 死磕以太坊源码分析之MPT树-上
死磕以太坊源码分析之MPT树-上 前缀树Trie 前缀树(又称字典树),通常来说,一个前缀树是用来存储字符串的.前缀树的每一个节点代表一个字符串(前缀).每一个节点会有多个子节点,通往不同子节点的路径 ...
- redis基础-Remote Dictionary Server
Redis支持多个数据库,并且每个数据库的数据是隔离的不能共享,并且基于单机才有,如果是集群就没有数据库的概念. Redis默认支持16个数据库(可以通过配置文件支持更多,无上限),可以通过配置dat ...
- ASP.NET Core路由中间件[2]: 路由模式
一个Web应用本质上体现为一组终结点的集合.终结点则体现为一个暴露在网络中可供外界采用HTTP协议调用的服务,路由的作用就是建立一个请求URL模式与对应终结点之间的映射关系.借助这个映射关系,客户端可 ...
- ElasticSearch--一、使用场景以及对应软件配置安装
废话不多说,直接来硬的!我在使用的时候使用的是mysql数据库. 一.ElasticSearch概念和使用场景 1.当我们需要搜索海量数据的时候,就可能会用到.以下使用的场景有哪些呢? 搜索海量数据 ...
- MySQL 集群知识点整理
随着项目架构的不断扩大,单台 MySQL 已经不能满足需要了,所以需要搭建集群将前来的请求进行分流处理.博客主要根据丁奇老师的专栏<<MySQL实战45讲>>学习的总结. 架构 ...
- 直播预告 | 开源的云原生开发环境 —— Nocalhost
直播来啦!本次云原生学院邀请到腾讯云 CODING DevOps 后端工程师王炜为大家分享<开源的云原生开发环境 -- Nocalhost>. 直播信息 讲师:王炜 - 腾讯云 CODIN ...
- 为了加快速度,Redis都做了哪些“变态”设计
前言 列表对象是 Redis 中 5 种基础数据类型之一,在 Redis 3.2 版本之前,列表对象底层存储结构有两种:linkedlist(双端列表)和 ziplist(压缩列表),而在 Redis ...