当前位置: 首页 > 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应用上
  • 分享一款本地音乐播放器源码
  • AHK 中 = 和 == 等比较运算符的用法
  • Apache Zeppelin在Apache Trafodion上的可视化
  • GDB 调试 Mysql 实战(三)优先队列排序算法中的行记录长度统计是怎么来的(上)...
  • Object.assign方法不能实现深复制
  • python大佬养成计划----difflib模块
  • Twitter赢在开放,三年创造奇迹
  • TypeScript迭代器
  • 分享自己折腾多时的一套 vue 组件 --we-vue
  • 给初学者:JavaScript 中数组操作注意点
  • 规范化安全开发 KOA 手脚架
  • 和 || 运算
  • 看图轻松理解数据结构与算法系列(基于数组的栈)
  • 使用权重正则化较少模型过拟合
  • 算法之不定期更新(一)(2018-04-12)
  • 推荐一个React的管理后台框架
  • 最简单的无缝轮播
  • 如何通过报表单元格右键控制报表跳转到不同链接地址 ...
  • ​水经微图Web1.5.0版即将上线
  • #AngularJS#$sce.trustAsResourceUrl
  • #define与typedef区别
  • #微信小程序:微信小程序常见的配置传值
  • $.ajax,axios,fetch三种ajax请求的区别
  • $分析了六十多年间100万字的政府工作报告,我看到了这样的变迁
  • (14)目标检测_SSD训练代码基于pytorch搭建代码
  • (2)STL算法之元素计数
  • (BFS)hdoj2377-Bus Pass
  • (k8s中)docker netty OOM问题记录
  • (Matlab)基于蝙蝠算法实现电力系统经济调度
  • (安卓)跳转应用市场APP详情页的方式
  • (分享)自己整理的一些简单awk实用语句
  • (三)docker:Dockerfile构建容器运行jar包
  • (转)负载均衡,回话保持,cookie
  • (轉貼) 蒼井そら挑戰筋肉擂台 (Misc)
  • ****Linux下Mysql的安装和配置
  • .bat批处理(四):路径相关%cd%和%~dp0的区别
  • .net mvc actionresult 返回字符串_.NET架构师知识普及
  • .NET3.5下用Lambda简化跨线程访问窗体控件,避免繁复的delegate,Invoke(转)
  • @autowired注解作用_Spring Boot进阶教程——注解大全(建议收藏!)
  • @GlobalLock注解作用与原理解析
  • @PreAuthorize注解