当前位置: 首页 > news >正文

CSS居中完全指南——构建CSS居中决策树

CSS居中完全指南——构建CSS居中决策树

clipboard.png

  • 本文总结CSS居中,包括水平居中和垂直居中.本文相当于CSS决策树,下次再遇到CSS居中问题时有章可循.
  • 参考Centering in CSS: A Complete Guide和【基础】这15种CSS居中的方式,你都用过哪几种
  • 本文的引用归原作者所有.
  • 代码在线演示工具JSbin使用指南

1.Horizontally 水平居中

1.1 inlineinline-*元素水平居中

给需要居中的元素一个block父元素,需要居中子元素为 文本 或者 inline, inline-block, inline-table, inline-flex

核心代码

.center-children {
  text-align: center;
}

JSbin演示地址
效果:
codeinline/code或codeinline-*/code元素水平居中

1.2block元素水平居中

父元素为block,子元素也为bolck,且子元素设置了宽度(没宽度子元素就继承父元素宽度,居中没有意义).
无论正在居中块级元素的宽度或父级的宽度如何,都会起作用。

方法:子元素margin: 0 auto;左右外边距设置为自动填充

核心代码

.center-me {
  margin: 0 auto;
}

效果:
codeblock/code元素水平居中

block元素水平居中JSbin演示地址

1.3多个block元素水平居中

1.3.1 多个block元素一行排列水平居中

  • 方法一:利用inline-block,原理是将子元素转化为inline-block.再用text-align: center;
  • 方法二:利用display: flex.注意:子元素高度会保持一致.看下方例子.

核心代码:

.inline-block-center {
  text-align: center;
}
.inline-block-center div {
  display: inline-block;
  text-align: left;
}

.flex-center {
  display: flex;
  justify-content: center;
}

效果:

多个codeblock/code元素一行排列水平居中
多个block元素一行排列水平居中JSbin演示地址

1.3.2 多个block元素每行一个水平居中

因为每个block元素独占一行,所以方法仍然是margin: 0 auto;

演示:
多个codeblock/code元素每行一个水平居中

多个block元素每行一个水平居中JSbin演示

2.Vertically垂直居中

垂直居中比较麻烦

2.1 inlineinline-* 元素单行垂直居中

需要垂直居中的元素为单行的inlineinline-* 元素,例如一个text或者a链接(包括a链接变化而成的按钮)

2.1.1 方法一:上下使用相同的padding(推荐)

上下和左右使用相同的padding可以不用设置宽高,既可以在修改文本内容是自适应,又可以减少出现BUG的几率.
核心代码:

.link {
  padding-top: 30px;
  padding-bottom: 30px;
}

演示:
方法一:上下使用相同的codepadding/code

方法一:上下使用相同的paddingJSbin演示地址

2.1.2 方法二:设置line-height与高度相同

核心代码

.center-text-trick {
  height: 100px;
  line-height: 100px;
  white-space: nowrap;
/*nowrap文本内的换行无效内容只能在一行显示*/
}

设置line-height与高度相同

设置line-height与高度相同JSbin演示地址

2.2 多行文本垂直居中

多行文本使用增加上下padding垂直居中的方法仍然有效且良好,不需设置宽高,推荐使用.
如果这样做不起作用,那么文本所在的元素可能是table或者table-cell元素,无论是真正的table还是后期自己添加的CSS.
下面说说这两种情况使用其他方法的垂直居中.

2.2.1:方法一:display: table;vertical-align: middle;

核心代码:

.center-table {
  display: table;
  
}
.center-table p {
  display: table-cell;
  vertical-align: middle;
}

多行文本垂直居中

table+vertical-align: middle多行文本垂直居中JSbin演示

2.2.2 使用flex布局多行文本居中

一个flex-child可以简单地在flex-parent的中心.
核心代码

.flex-center-vertically {
  display: flex;
  justify-content: center;
  flex-direction: column;
  height: 400px;
}

使用codeflex/code多行文本居中

使用flex多行文本居中JSbin演示地址

2.3 block元素垂直居中

2.3.1已知block元素高度

原理是绝对定位,top: 50%;然后 margin-top设置为负边距且值为他本身高度的一半.
核心代码:

.parent {
  position: relative;
}
.child {
  position: absolute;
  top: 50%;
  height: 100px;
  margin-top: -50px; /* account for padding and border if not using box-sizing: border-box; */
}
注意:使用 position: absolute;绝对定位会使元素脱离文档流

clipboard.png

已知block元素高垂直居中演示

2.3.2 block元素高度未知垂直居中

借助CSS3中的transform属性向Y轴反向偏移50%的方法实现垂直居中。但是部分浏览器存在兼容性的问题。
核心代码:

.parent {
  position: relative;
}
.child {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
}

transform用法

codeblock/code元素高度未知垂直居中
block元素高度未知垂直居中JSbin演示

2.3.3 使用flex布局block元素高度未知垂直居中

核心代码:

.parent {
  display: flex;
  flex-direction: column;
  justify-content: center;
}

用flex布局codeblock/code元素高度未知垂直居中

用flex布局block元素高度未知垂直居中JSbin演示

3.Both Horizontally and Vertically水平垂直居中

3.1有固定宽高的元素

核心代码:
依旧是绝对定位+宽高一半的负边距

.parent {
  position: relative;
}

.child {
  width: 300px;
  height: 100px;
  padding: 20px;

  position: absolute;
  top: 50%;
  left: 50%;

  margin: -70px 0 0 -170px;
}

有固定宽高的元素

有固定宽高的元素JSbin演示

3.2 宽高不固定

利用2D变换,在水平和垂直两个方向都向反向平移宽高的一半,从而使元素水平垂直居中。

核心代码

.parent {
  position: relative;
}
.child {
  position: absolute;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
}

不知宽高

宽高不固定水平垂直居中JSbin演示

3.3 使用flex布局垂直水平居中

核心代码:

.parent {
  display: flex;
  justify-content: center;
  align-items: center;
}

使用flex布局垂直水平居中

使用flex布局垂直水平居中JSbin演示

3.4 使用grid布局垂直水平居中

核心代码:

body, html {
  height: 100%;
  display: grid;
}
span { /* thing to center */
  margin: auto;
}

使用flex布局垂直水平居中

使用flex布局垂直水平居中JSbin演示

相关文章:

  • 悲观的并发策略——synchronized互斥锁
  • 一步一步构建自己的管理系统之 ------登入注册
  • 64位linux安装wine等软件
  • javascript 日期函数
  • spring IOC AOP实现原理
  • Python数据挖掘与机器学习技术入门实战
  • 万达酒店及度假村首创微信智能开票辅助功能
  • 【vue】vue +element 搭建项目,vuex中的store使用
  • 面向对象进阶------模块 json pickle hashlib
  • ApiLeaf·可能是史上最省事的文档生成工具
  • CSDN日报20170226——《你离心想事成仅仅差一个计划》
  • 云服务能力评估“国标”出炉,新华三首批通过增强级认证
  • 会话管理(session)
  • 在Office应用中打开WPF窗体并且让子窗体显示在Office应用上
  • 分享一款本地音乐播放器源码
  • ----------
  • 【108天】Java——《Head First Java》笔记(第1-4章)
  • 【划重点】MySQL技术内幕:InnoDB存储引擎
  • fetch 从初识到应用
  • input的行数自动增减
  • java多线程
  • React组件设计模式(一)
  • uva 10370 Above Average
  • vagrant 添加本地 box 安装 laravel homestead
  • 聊聊springcloud的EurekaClientAutoConfiguration
  • 我看到的前端
  • 一天一个设计模式之JS实现——适配器模式
  • 在Mac OS X上安装 Ruby运行环境
  • 最近的计划
  • 扩展资源服务器解决oauth2 性能瓶颈
  • ​Spring Boot 分片上传文件
  • ​力扣解法汇总946-验证栈序列
  • ​软考-高级-信息系统项目管理师教程 第四版【第23章-组织通用管理-思维导图】​
  • # 睡眠3秒_床上这样睡觉的人,睡眠质量多半不好
  • #LLM入门|Prompt#1.8_聊天机器人_Chatbot
  • (BFS)hdoj2377-Bus Pass
  • (done) ROC曲线 和 AUC值 分别是什么?
  • (Matlab)使用竞争神经网络实现数据聚类
  • (PHP)设置修改 Apache 文件根目录 (Document Root)(转帖)
  • (Redis使用系列) SpringBoot 中对应2.0.x版本的Redis配置 一
  • (TOJ2804)Even? Odd?
  • (接口封装)
  • (没学懂,待填坑)【动态规划】数位动态规划
  • (四) Graphivz 颜色选择
  • (算法二)滑动窗口
  • (小白学Java)Java简介和基本配置
  • (转)setTimeout 和 setInterval 的区别
  • (转)树状数组
  • (转)四层和七层负载均衡的区别
  • (转载)Google Chrome调试JS
  • ****** 二十三 ******、软设笔记【数据库】-数据操作-常用关系操作、关系运算
  • .java 9 找不到符号_java找不到符号
  • .NET 8.0 发布到 IIS
  • .NET Core 中插件式开发实现
  • .net 调用php,php 调用.net com组件 --