查看原文可以有更好的排版效果哦

前言

居中是平时工作中的最常见的一种需求,各种图片居中或者各种弹窗,水平居中还好,特别是垂直居中,很多初学者表示太难写了,现在列举一些常用的方法。

实战

这里只讲述css相关的方法,js暂时不提,毕竟这是样式上的事情,就不劳烦js出手了。

1. top 50% ;margin-top:-自身高度/2

记得最早工作的时候学到的第一个方法就是,top50%,然后把自身向上移动自身高度的一半,具体实现是

<style>
.content{
position:relative;
width:500px;
height:400px;
border:1px solid black;
}
.box{
positon:absolute;
width:200px;
height:200px;
background:orange;
top:50%;
margin-top:-100px;
}
</style> <div class="content">
<div class="box"></div>
</div>

这样就很容易实现了垂直居中,但这种必须要知道自身的高度,才能使用margin-top:-100px这种来达到目的。

优点: 写法简单,兼容性好

缺点: 必须知道目标元素的高度,而且高度必须是固定的值,否则样式要跟着相应的改动,不够灵活

2. top 50% ; transforms:translateY(-50%)

这个方法和上述原理一致,只不过向上位移换成了transforms:translateY写法

.box{
positon:absolute;
width:200px;
height:200px;
background:orange;
top:50%;
transforms:translateY(-50%)
}

由于用到了css3的新特性,所以对浏览器的要求就比较高了

优点: 写法简单,适应性好

缺点: 兼容性一般,不支持ie8浏览器

3. margin:auto

大家平时可能都用过margin:0 auto来实现一个div水平居中吧,其实也是可以做垂直居中的。

.box{
positon:absolute;
width:200px;
height:200px; /**必须要指明宽高**/
background:orange;
top:0;
bottom:0;
margin:auto
}

是不是很神奇?但是有个地方要注意的是,这个必须要指明宽高,不然的话top:0;bottom:0就把容器撑满了。

优点: 写法简单,适应性好,兼容性好

缺点: 需要指明元素宽高,如果目标元素宽高是变化的,你可以通过js来辅助生成

4. vertical-align:middle

这个方法是我最喜欢用的一个方法,基本满足上述的全部要求,主要用到了多个元素vertical-align:middle实现垂直居中,由于需要多个元素才能生效(不然一个元素跟谁对齐呢),所以再添加一个i标签

<style>
.box{
display:inline-block;/**必须是inline-block类型**/
width:200px;
height:200px;
background:orange;
vertical-align:middle;
}
.m{
display:inline-block;/**必须是inline-block类型**/
width:0;
height:100%;
vertical-align:middle;
}
</style> <div class="content">
<i class="m"></i>
<div class="box"></div>
</div>

这样就实现垂直居中,而且不需要关注目标元素的尺寸,适应性强

通常我在用的时候用用一个伪元素来代替,避免在html中新增结构

<style>
/**单独用一个类名表示,可作为公共样式**/
.mfix{
font-size:0;/**消除空隙**/
}
.mfix:before{
content:'';
display:inline-block;
width:0;
height:100%;
vertical-align:middle;
}
.mfix>*{
display:inline-block;
vertical-align:middle;
} .box{
width:200px;
height:200px;
background:orange;
vertical-align:middle;
}
</style> <div class="content mfix"> <!--添加一个mfix类名-->
<div class="box"></div>
</div>

这样在需要垂直居中的父级上添加一个.mfix就可以实现垂直居中了。

优点: 适应性好,兼容性好

缺点: 可能稍微有点复杂吧。

5. writing-mode

这个方法是在张鑫旭的博客中发现的,也挺有意思。

正常情况下比如text-align:centerinline-block元素可以实现水平居中,假设我们通过writing-mode将水平流改成竖直流,不就形成垂直居中了吗?

在父级上加上如下样式

.content{
writing-mode: tb-rl; /**内容从上往下(top-bottom),从右往左(right-left)垂直流动,下面是一些兼容性写法**/
-webkit-writing-mode: vertical-rl;
writing-mode: vertical-rl;
text-align: center;
}

这样也可以做到垂直居中,不过要注意的是,现在里面的文本也会变成从上到下排列,所以需要重置一下。

还有一个问题就是,如果这个时候要想水平居中就gg了,原理和刚才反过来,可以通过套一层改变流向来解决,具体实现可以参考demo

优点: 适应性好,兼容性好

缺点: 算是一个偏方吧。而且writing-mode的语法太杂,各种各样的,所以。。玩玩就好

6. flex大法

这个方法接触过css3的应该都接触过吧,只要在父级加上如下代码就能实现垂直居中了

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

如果对浏览器没什么要求,尽量都用这种方式吧。

优点: 写法简单,适应性好

缺点: 兼容性一般,不支持ie8浏览器

小节

以上共有6种方式来实现垂直居中的效果,个人是最青睐第4种方式的,兼容性好,适应性好,各位小伙伴还有没有其他的实现方式呢?

css 垂直居中方法汇总的更多相关文章

  1. 最常用的css垂直居中方法

    css垂直居中一直以来都是一个被大家说烂了的话题,翻来覆去的炒.不过说实话,正是因为css没有提供标准的垂直居中方法(不过在css3中已经有了相关规范),所以大家才会对它进行专门的研究.这研究来研究去 ...

  2. css垂直居中方法

    CSS垂直居中的简便方法:{position:absolute;left:0;bottom:0;top:0;right:0;margin:auto;}.

  3. css 文本和div垂直居中方法汇总

    https://blog.csdn.net/u014607184/article/details/51820508 https://blog.csdn.net/liuying1802028915/ar ...

  4. css垂直居中方法总结

    在网页布局中,我们往往会遇到下图所示的场景,让小图标和文字对齐 可能有的小伙伴会说,这个简单,直接给小图标设置左浮动来实现. 这样做是可以的,但不推荐,毕竟浮动是会影响布局的,能少用还是少用. 以前遇 ...

  5. css垂直居中方法(四)

    第六种方法,使用css的writing-mode属性,结合margin:auto. 参考文章:改变CSS世界纵横规则的writing-mode属性 传统的web流中,margin设置auto值的时候, ...

  6. css 垂直居中方法总结

    工作中遇到垂直居中问题,特此总结了一下几种方式与大家分享.本文讨论的垂直居中仅支持IE8+ 1.使用绝对定位垂直居中 HTML <div class="container"& ...

  7. css垂直居中方法盘点

    1.单行文字垂直居中 利用 line-height 即可轻松实现,如下示例: height:45px;line-height:45px; 2.多行文本固定高度垂直居中1 利用 display:tabl ...

  8. [css] 垂直居中方法

    原文链接:http://www.cnblogs.com/2050/p/3392803.html 一.text-algin:center; 适用于行内元素水平居中,如图片.按钮.文字, 但是在IE67下 ...

  9. css垂直居中方法(二)

    第四种方法: 这个方法把一些div的显示方式设置为表格,因此我们可以使用表格的vartial-align属性. 代码如下: <!doctype html> <html lang=&q ...

随机推荐

  1. python 中的迭代器和生成器简单介绍

    可迭代对象和迭代器 迭代(iterate)意味着重复,就像 for 循环迭代序列和字典那样,但实际上也可使用 for 循环迭代其他对象:实现了方法 __iter__ 的对象(迭代器协议的基础). __ ...

  2. Python:HTTP请求头headers信息的查询

    GET和POST请求后会返回一个response对象,可通过key.values等访问字典中元素的方式来访问该response对象headers中的各种属性 r=requests.get(url,he ...

  3. Tableau绘制K线图、布林线、圆环图、雷达图

    Tableau绘制K线图.布林线.圆环图.雷达图 本文首发于博客冰山一树Sankey,去博客浏览效果更好.直接右上角搜索该标题即可 一. K线图 1.1 导入数据源 1.2 拖拽字段 将[日期]托到列 ...

  4. JZ-031-从 1 到 n 整数中 1 出现的次数

    从 1 到 n 整数中 1 出现的次数 题目描述 求出1-13的整数中1出现的次数,并算出100-1300的整数中1出现的次数?为此他特别数了一下1~13中包含1的数字有1.10.11.12.13因此 ...

  5. SQL Server的Linked Servers

    文章搬运自:SQL Server的Linked Servers(链接) 参考引用一下,感谢作者~ 我们在使用SQL Server时,有时会有这种需求,需要从一个SQL Server服务器A中,查询另一 ...

  6. 2022年官网下安装RedisDesktopManager最全版与官网查阅方法

    目录 安装部署RedisDesktopManager 一.下载安装 1.浏览器输入网址:https://github.com/ ,输入搜索条件,找到如图,双击 2.滑动浏览器找到如图位置,双击 3.滑 ...

  7. 关于php接受xml的一些问题,simplexml_load_string收不到数据

    接受xml数据一般使用这两种方法 方法1: file_get_contents('php://input'); 方法2: simplexml_load_string($GLOBALS['HTTP_RA ...

  8. es-kibana基本使用

  9. CF1117G题解

    题意:区间建笛卡尔树,求每个节点的siz之和. 首先看到笛卡尔树,就应该想到,因为这是一个排列,可以找到通过左边和右边第一个比自己大的元素来"建立"笛卡尔树. 设 \(l(u)\) ...

  10. 学习HashMap源码

    HashMap简介 ​ HashMap是一种存储K-V类型的容器,HashMap底层数据结构为数组+链表+红黑树(jdk 1.8新增),它根据键的HashCode值存储数据,获取元素的时间复杂度为O( ...