CSS居中对齐终极指南
本文首发于我的公众号:前端新世界
欢迎关注
本文将讨论可用于居中对齐元素的6种CSS技术(按照最佳实践排序),以及每一种技术最适合应用的场景。这里,居中对齐指的是将元素放置在其父元素的水平和垂直中心。
.center类代表要居中对齐的元素
.parent类代表其父元素。
1. 使用变换(Transform)
什么时候用:
- 当元素的宽度和高度未知时;
- 卡片式弹出框中有多个子元素,其中一个焦点元素位于中心。
这个思路是使用绝对定位——top和left 50%,然后应用负变换。top和left中使用的值根据父元素的尺寸解析,而translate方法中的值根据元素本身的尺寸解析。
.center {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
2. 使用Flex
什么时候用:
- 当有一个或多个元素要居中时;
- 当子元素是动态的并且大小未知时;
- 当有一行项目需要像页脚一样居中时。
这个思路是使父容器成为flexbox并使用flex属性将元素沿水平和垂直方向居中,如下所示。
.parent {
display: flex;
justify-content: center;
align-items: center;
}
当有多个元素需要一个在另一个元素上方堆叠,并使该元素堆叠在其中心时,我们只需添加以下代码行:
flex-direction: column;
3. 使用负边距
什么时候用:
- 当元素的高度和宽度已知时。
这个思路是再次使用类似于变换技术的绝对定位,但应用的是元素宽度和高度一半的负边距而不是平移。
$w: 200px; /* SCSS 变量 */
$h: 100px; /* SCSS 变量 */
.center {
position: absolute;
top: 50%;
left: 50%;
margin: -50px -100px; /* Negative margin of half the
width and heigh */t
}
为了使这段代码更通用,我们使用calc()属性,如下所示:
(#{$h} / 2) - 一半高度
(#{$h} / 2) * -1) - 一半高度的负值
这样就可以:
margin: calc((#{$h} / 2) * -1) calc((#{$w} / 2) * -1);
4. 使用网格(Grid)
什么时候用:
- 当只有一个子元素需要居中时。
这个思路是创建一个网格容器并将边距设置为auto。在非网格容器中,当margin设置为auto时,margin-top和bottom取值为0。
但是,在网格容器中,margin-top和bottom平均分配可用空间,从而使元素居中。
.parent {
display: grid;
}
.center {
margin: auto;
}
另一种使用网格来实现居中的方法是:
.parent {
display: grid;
place-items: center;
}
5. 使用填充(Padding)
不建议将此技术用于中心对齐,但它也是可行的。
什么时候用:
- 当父元素的高度已知或者固定时;
- 当中心元素的高度为弹性可变时。
这个思路是为已知固定高度的容器设置固定的垂直填充,并允许子元素占据最大高度和自动边距。
.parent {
height: 600px; //Fixed height
padding: 200px 0; //Fixed vertical padding
}
.center{
margin: 0 auto;
height: 100%; // Child takes max height
}
6. 使用表格单元格
这个技术现在用得比较少,但是也值得借鉴。并且,它确实也是可行的。
这个思路是使用display强制父级表现得像一个表格单元格。然后使用vertical align属性进行垂直居中,使用margin auto进行水平居中。
.parent {
display: table-cell;
vertical-align: middle;
}
.center{
margin: auto;
}
以上总结了居中对齐元素的6种方法。
另外我们再讲一讲——水平居中
水平居中通常用于标题样式和页脚,并结合均匀的填充或边距。
使用文本对齐
什么时候用:
- 当中心元素为文本内容或者
inline-*类型元素时; linline-*包括inline、inline-block、inline-flex、inline-table等。
.parent {
text-align: center;
}
它还可以居中块类型子元素,但我们不推荐这么做。
使用边距
什么时候用:
- 当中心元素是块元素时
.center {
margin: 0 auto;
}
感谢阅读!
每日分享前端插件和前端开发教程,欢迎扫码关注我的公众号:前端新世界

CSS居中对齐终极指南的更多相关文章
- CSS居中对齐
CSS实现居中对齐的几种方式 页面布局中,居中对齐是我们经常遇到的场景,现在总结几个常用的方式供大家参考. 场景一:按钮文字居中对齐,line-height + text-align html代码: ...
- CSS 居中效果完整指南
本文翻译自:<Centering in CSS: A Complete Guide> 使用 CSS 实现效果困难吗?显然不是.实际上有许多方法可以实现居中效果,但在具体情况中,我们往往无法 ...
- 利用CSS实现居中对齐
1. 文本居中 首先编写一个简单的html代码,设置一个类名为parentDiv的div对象.html代码如下: <div class="parentDiv"> 这里随 ...
- CSS 图像居中对齐
CSS 图像居中对齐 我们在<CSS 内外边距>学过内容居中,它的原理是将外边左右设置为auto.图像居中也是这个原理. 示例 <!DOCTYPE html> <htm ...
- CSS居中完全指南——构建CSS居中决策树
CSS居中完全指南--构建CSS居中决策树 本文总结CSS居中,包括水平居中和垂直居中.本文相当于CSS决策树,下次再遇到CSS居中问题时有章可循. 参考Centering in CSS: A Com ...
- 【css对齐】块内或者行内图片与文字居中对齐最靠谱的方式!
块内或者行内图片与文字居中对齐最靠谱的方式! 做图片与文字在一行的按钮时候最常用到,总结了一个靠谱的方法,终于可以完美的对齐下面给个代码 首先是html: <p class="btnU ...
- CSS上下左右居中对齐
上下左右居中对齐 display: inline/inline-block 将父元素(容器)设定 text-align: center: 即可左右置中. display: block 将元素本身的 ...
- vue—你必须知道的 js数据类型 前端学习 CSS 居中 事件委托和this 让js调试更简单—console AMD && CMD 模式识别课程笔记(一) web攻击 web安全之XSS JSONP && CORS css 定位 react小结
vue—你必须知道的 目录 更多总结 猛戳这里 属性与方法 语法 计算属性 特殊属性 vue 样式绑定 vue事件处理器 表单控件绑定 父子组件通信 过渡效果 vue经验总结 javascript ...
- line-height,vertical-align及图片居中对齐问题根源解析
关于图片居中对齐的问题,进入前端行业虽然有一段时间了,以为自己懂了,可是实际上还是一知半解,找了一些博客来看了一下,但是感觉讲的有点碎,看完还是一知半解. 查阅了一下<css权威指南>,结 ...
随机推荐
- mybatis学习——日志工厂
为什么要使用日志工厂? 我们想一下,我们在测试SQL的时候,要是能够在控制台输出 SQL 的话,是不是就能够有更快的排错效率?答案是肯定的,如果一个 数据库相关的操作出现了问题,我们就可以根据输出的S ...
- 『心善渊』Selenium3.0基础 — 3、使用Selenium操作浏览器对象的基础API
目录 1.导入Selenium库 2.创建浏览器对象 3.浏览器窗口大小设置 4.浏览器位置设置 5.请求访问网址 6.浏览器页面前进.后退和刷新 7.关闭浏览器 相比于高大上的各种Selenium进 ...
- 写DockerFile的一些技巧
Docker镜像由只读层组成,每个层都代表一个Dockerfile指令.这些层是堆叠的,每一层都是前一层变化的增量.示例Dockerfile: FROM ubuntu:15.04 COPY . / ...
- IP地址与子网的划分
一.IP地址 1.IP地址的定义 (1).IP地址有32位二进制数组成,一般用点分十进制来表示 (2).IP地址由两部分组成 网络部分(NETWORK) 主机部分(HOST) 2.IP地址的分类 IP ...
- Kubernetes使用节点亲缘性将POD调度到特定节点上
节点污点可以用来让pod远离特定的节点,尽量在不修改已有pod信息的前提,通过在节点添加污点信息,来拒绝pod在某些节点上的部署. 而现在介绍一种叫做节点亲缘性,通过明确的在pod中添加的信息,来决定 ...
- HTTPD之二————HTTPD服务详解————httpd的配置文件常见设置
HTTPD之二----HTTPD服务详解----httpd的配置文件常见设置 HTTP服务器应用 http服务器程序 httpd apache nginx lighttpd 应用程序服务器 IIS,a ...
- 在线CRM系统对企业的好处有哪些
随着信息技术的飞速发展,每个企业都希望通过互联网技术来让自身发展壮大.由于强大的管理能力和技术手段,在线CRM系统成为了企业用来管理自身获得发展的最佳选择.那么在线CRM系统对企业来说有哪些好处呢?本 ...
- CRM系统什么时候需要使用
CRM客户关系管理系统,相信每个人都会有所了解.现如今随着企业的发展需求,CRM软件已经成为了企业管理的刚需.无论是何种行业和规模的企业,客户都是最重要的资源,提高客户满意度也是企业的首要任务.如果您 ...
- Spring-Redis缓存业务优化(通配符删除、两种自定义缓存时长)
application.yml配置 spring: cache: type: REDIS redis: time-to-live: PT300S # 默认缓存秒数 ...
- Sentinel流控与熔断
参考: https://thinkwon.blog.csdn.net/article/details/103770879 项目结构 com.guo ├── guo-sentinel ...