CSS居中完全指南——构建CSS居中决策树
CSS居中完全指南——构建CSS居中决策树
- 本文总结CSS居中,包括水平居中和垂直居中.本文相当于CSS决策树,下次再遇到CSS居中问题时有章可循.
- 参考Centering in CSS: A Complete Guide和【基础】这15种CSS居中的方式,你都用过哪几种
- 本文的引用归原作者所有.
- 代码在线演示工具JSbin使用指南
1.Horizontally 水平居中
1.1 inline
或inline-*
元素水平居中
给需要居中的元素一个block
父元素,需要居中子元素为 文本 或者 inline
, inline-block
, inline-table
, inline-flex
核心代码
.center-children {
text-align: center;
}
JSbin演示地址
效果:
1.2block
元素水平居中
父元素为block
,子元素也为bolck
,且子元素设置了宽度(没宽度子元素就继承父元素宽度,居中没有意义).
无论正在居中块级元素的宽度或父级的宽度如何,都会起作用。
方法:子元素margin: 0 auto;
左右外边距设置为自动填充
核心代码
.center-me {
margin: 0 auto;
}
效果:
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;
}
效果:
1.3.2 多个block
元素每行一个水平居中
因为每个block
元素独占一行,所以方法仍然是margin: 0 auto;
演示:
2.Vertically垂直居中
垂直居中比较麻烦
2.1 inline
或 inline-*
元素单行垂直居中
需要垂直居中的元素为单行的inline
或 inline-*
元素,例如一个text或者a链接(包括a链接变化而成的按钮)
2.1.1 方法一:上下使用相同的padding
(推荐)
上下和左右使用相同的padding
可以不用设置宽高,既可以在修改文本内容是自适应,又可以减少出现BUG的几率.
核心代码:
.link {
padding-top: 30px;
padding-bottom: 30px;
}
演示:
2.1.2 方法二:设置line-height
与高度相同
核心代码
.center-text-trick {
height: 100px;
line-height: 100px;
white-space: nowrap;
/*nowrap文本内的换行无效内容只能在一行显示*/
}
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;
}
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;
绝对定位会使元素脱离文档流
2.3.2 block
元素高度未知垂直居中
借助CSS3中的transform
属性向Y轴反向偏移50%的方法实现垂直居中。但是部分浏览器存在兼容性的问题。
核心代码:
.parent {
position: relative;
}
.child {
position: absolute;
top: 50%;
transform: translateY(-50%);
}
2.3.3 使用flex布局block
元素高度未知垂直居中
核心代码:
.parent {
display: flex;
flex-direction: column;
justify-content: center;
}
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;
}
3.2 宽高不固定
利用2D变换,在水平和垂直两个方向都向反向平移宽高的一半,从而使元素水平垂直居中。
核心代码
.parent {
position: relative;
}
.child {
position: absolute;
top: 50%;
left: 50%;
transform: translate(-50%, -50%);
}
3.3 使用flex
布局垂直水平居中
核心代码:
.parent {
display: flex;
justify-content: center;
align-items: center;
}
3.4 使用grid
布局垂直水平居中
核心代码:
body, html {
height: 100%;
display: grid;
}
span { /* thing to center */
margin: auto;
}
CSS居中完全指南——构建CSS居中决策树的更多相关文章
- CSS 动画一站式指南
CSS 动画一站式指南 目录 CSS 动画一站式指南 1. CSS 动画 1.1 变换 1.1.1 变换属性介绍 1.1.2 变换动画实践 1.2 过渡 1.2.1 过渡属性介绍 1.2.2 过渡动画 ...
- css居中完全指南(翻译)
最近参加了百度的前端技术学院,任务4是要求一个元素在父元素中水平和垂直居中,提供的一篇文章对各种情况都进行了分析,很不错,英文也不是那么难懂,毕竟代码还是主体,翻译过来分享出来,翻译内容带有自己的理解 ...
- !!!css如何让img图片居中?css的display属性实现图片居中(代码实例)
在我们开发前端页面的时候,为了让页面效果美观,会让图片呈现居中效果.那么css怎么让img图片居中显示呢?本篇文章给大家带来css如何让img图片居中?css的display属性实现图片居中(代码实例 ...
- css垂直居中怎么设置?文字上下居中和图片垂直居中
css 居中分css垂直居中和css水平居中,水平居中平时比较常用,这里我们主要讲css上下居中的问题.垂直居中又分为css文字上下居中和css图片垂直居中,下面我们就分别来介绍一下. css文字上下 ...
- 右边根据左边的高度自动居中只需要两行CSS就可以完成
右边根据左边的高度自动居中只需要两行CSS就可以完成 <style type="text/css" > div{ display: inline-block; vert ...
- CSS权威指南之css声明,伪类,文本处理--(简要笔记一)
1.css层叠的含义 后面的会覆盖前面的样式 2.每个元素生成一个框,也称盒. 3.替换元素和非替换元素. img如果不指定src的外部路径,该元素就没有意义.他由文档本身之外的一个图像文件来替换 ...
- Gulp学习指南之CSS合并、压缩与MD5命名及路径替换(转载)
本文转载自: Gulp学习指南之CSS合并.压缩与MD5命名及路径替换
- CSS Flexbox 学习指南、工具与框架
Flexbox 是一种更有效的布局方式,它能更好的分配容器空间,并控制项目的对齐.虽然,掌握它的理论有些复杂,但幸运的是,我们可以借助开放的网络来学习并逐步掌握它. 在本文中,我们整合了一些最佳的 F ...
- HTML 5与CSS 3权威指南(第2版·上册) 中文pdf扫描版
HTML5与CSS3权威指南(第2版·上册)已经成为HTML 5与CSS 3图书领域的一个标杆,被读者誉为“系统学习HTML 5与CSS 3技术的最佳指导参考书之一”和“Web前端工程师案头必备图书之 ...
随机推荐
- easyhook源码分析三——申请钩子
EasyHook 中申请钩子的原理介绍 函数原型 内部使用的函数,为给定的入口函数申请一个hook结构. 准备将目标函数的所有调用重定向到目标函数,但是尚未实施hook. EASYHOOK_NT_IN ...
- 安装ubuntu双系统
今天在win7下安装ubuntu14.1双系统,别折磨了一个下午.主要是开机系统引导问题. 引导程序是位于硬盘最前面的一段程序,由于扇区大部分是引导程序,故也成引导扇区.此外包含有硬盘的分区信息,共6 ...
- jenkins不展示set Build Description Setter插件
问题描述: 1.jenkins 已下载 set build descripteion ,并且配置过,可以在构建历史中展示就用二维码 2.问题:构建历史中不展示二维码了,如图: 总是排查: 1.首先想到 ...
- Linux下编译安装Python-3.6.5
1.下载Python-3.6.5安装包 在Python官网(https://www.python.org/downloads/)下载对应的安装包,选择3.6.5的linux版本,如下图: 2.将安装包 ...
- 中国MOOC_零基础学Java语言_第7周 函数_2完数
2 完数(5分) 题目内容: 一个正整数的因子是所有可以整除它的正整数.而一个数如果恰好等于除它本身外的因子之和,这个数就称为完数.例如6=1+2+3(6的因子是1,2,3). 现在,你要写一个程序, ...
- spring boot + mybatis 连接 oracle 出现 ORA-00923: 未找到要求的 FROM 关键字 错误
1.原因 hikari 连接池配置错误,mysql和oracle的配置不一样 2.修改 spring: datasource: hikari: connection-test-query: selec ...
- 【MM系列】SAP 簇表 A017 物料信息记录 (指定工厂) 包含的透明表
公众号:SAP Technical 本文作者:matinal 原文出处:http://www.cnblogs.com/SAPmatinal/ 原文链接:[MM系列]SAP 簇表 A017 物料信息记录 ...
- 多变量分析绘图(hue参数)以及盒图和小提琴图
1,函数stipplot() stipplot()函数用来画散点图,其x轴是离散型的变量 直接上代码 import seaborn as sns import numpy as np import p ...
- Java第三周课程总结&实验报告一
第三周课程总结 1.关于面向对象的一些具体内容,明白了类与对象以及Java的封装性和构造方法以及对对象匿名的相关知识. 2.this关键字,它是表示类的成员属性(变量),使用this构造方法时必须放在 ...
- tensorflow白话篇
接触机器学习也有相当长的时间了,对各种学习算法都有了一定的了解,一直都不愿意写博客(借口是没时间啊),最近准备学习深度学习框架tensorflow,决定还是应该把自己的学习一步一步的记下来,方便后期的 ...