当前位置: 首页 > 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应用上
  • 分享一款本地音乐播放器源码
  • [case10]使用RSQL实现端到端的动态查询
  • canvas实际项目操作,包含:线条,圆形,扇形,图片绘制,图片圆角遮罩,矩形,弧形文字...
  • docker python 配置
  • egg(89)--egg之redis的发布和订阅
  • java中具有继承关系的类及其对象初始化顺序
  • Mysql优化
  • SpringBoot 实战 (三) | 配置文件详解
  • SpriteKit 技巧之添加背景图片
  • 翻译 | 老司机带你秒懂内存管理 - 第一部(共三部)
  • 关于springcloud Gateway中的限流
  • 前端学习笔记之原型——一张图说明`prototype`和`__proto__`的区别
  • 如何邀请好友注册您的网站(模拟百度网盘)
  • 入门到放弃node系列之Hello Word篇
  • 使用 5W1H 写出高可读的 Git Commit Message
  • 通过来模仿稀土掘金个人页面的布局来学习使用CoordinatorLayout
  • Android开发者必备:推荐一款助力开发的开源APP
  • ​中南建设2022年半年报“韧”字当头,经营性现金流持续为正​
  • # Panda3d 碰撞检测系统介绍
  • # Pytorch 中可以直接调用的Loss Functions总结:
  • # 睡眠3秒_床上这样睡觉的人,睡眠质量多半不好
  • #NOIP 2014# day.1 生活大爆炸版 石头剪刀布
  • #QT项目实战(天气预报)
  • $HTTP_POST_VARS['']和$_POST['']的区别
  • $jQuery 重写Alert样式方法
  • (8)Linux使用C语言读取proc/stat等cpu使用数据
  • (Forward) Music Player: From UI Proposal to Code
  • (LeetCode) T14. Longest Common Prefix
  • (解决办法)ASP.NET导出Excel,打开时提示“您尝试打开文件'XXX.xls'的格式与文件扩展名指定文件不一致
  • (九)c52学习之旅-定时器
  • (一)【Jmeter】JDK及Jmeter的安装部署及简单配置
  • (转)程序员技术练级攻略
  • ./和../以及/和~之间的区别
  • .Net 中的反射(动态创建类型实例) - Part.4(转自http://www.tracefact.net/CLR-and-Framework/Reflection-Part4.aspx)...
  • .NET6使用MiniExcel根据数据源横向导出头部标题及数据
  • .NET应用架构设计:原则、模式与实践 目录预览
  • ??如何把JavaScript脚本中的参数传到java代码段中
  • [Android] 240204批量生成联系人,短信,通话记录的APK
  • [Android]Android P(9) WIFI学习笔记 - 扫描 (1)
  • [C和指针].(美)Kenneth.A.Reek(ED2000.COM)pdf
  • [DM复习]Apriori算法-国会投票记录关联规则挖掘(上)