我们都知道 margin:0 auto; 的样式能让元素水平居中,而 margin: auto; 却不能做到垂直居中……直到现在。但是,请注意!想让元素绝对居中,只需要声明元素高度,并且附加以下样式,就可以做到:

CSS Code复制内容到剪贴板

.Absolute-Center {

margin:auto;

position:absolute;

top: 0;left: 0;bottombottom: 0;rightright: 0;

}

我并不是第一个发现这种方法的人(不过我还是敢把它叫做“完全居中”),它有可能是种非常普遍的技巧。但大多数介绍垂直居中的文章中并没有提到过这种方法。

以前从未用过这种方法的我想试试,看看这种”完全居中”的方法到底有多么神奇。 好处:

跨浏览器,兼容性好(无需hack,可兼顾IE8~IE10)

无特殊标记,样式更精简

自适应布局,可以使用百分比和最大最小高宽等样式

居中时不考虑元素的padding值(也不需要使用box-sizing样式)

布局块可以自由调节大小

img的图像也可以使用

同时注意:

必须声明元素高度

推荐设置overflow:auto;样式避免元素溢出,显示不正常的问题

这种方法在Windows Phone上不起作用

浏览器支持:Chrome、Firefox、Safari、Mobile Safari、IE8-10。 “完全居中”经测试可以完美地应用在最新版本的Chrome、Firefox、Safari、Mobile Safari中,甚至也可以运行在IE8~IE10上

对照表

“完全居中”并不是本篇文章中唯一的选项。要做到垂直居中,还存在着其他方法,各有各的长处。采取什么样的方法,取决于你所支持的浏览器,以及现有标签的结构。下面这张对照表能够帮你选出最符合你需要的方法。

说明

在研究了规范和文档后,我总结出了“完全居中”的工作原理:

1.在普通文档流里,margin: auto; 的意思是设置元素的margin-top和margin-bottom为0。

W3.org If ‘margin-top’, or ‘margin-bottom’ are ‘auto’, their used value is 0.

2. 设置了position: absolute; 的元素会变成块元素,并脱离普通文档流。而文档的其余部分照常渲染,元素像是不在原来的位置一样。 Developer.mozilla.org …an element that is positioned absolutely is taken out of the flow and thus takes up no space

3. 设置了top: 0; left: 0; bottom: 0; right: 0; 样式的块元素会让浏览器为它包裹一层新的盒子,因此这个元素会填满它相对父元素的内部空间,这个相对父元素可以是是body标签,或者是一个设置了position: relative; 样式的容器。 Developer.mozilla.org For absolutely positioned elements, the top, right, bottom, and left properties specify offsets from the edge of the element’s containing block (what the element is positioned relative to).

4. 给元素设置了宽高以后,浏览器会阻止元素填满所有的空间,根据margin: auto; 的要求,重新计算,并包裹一层新的盒子。 Developer.mozilla.org The margin of the [absolutely positioned] element is then positioned inside these offsets.

5. 既然块元素是绝对定位的,又脱离了普通文档流,因此浏览器在包裹盒子之前会给margin-top和margin-bottom设置一个相等的值。 W3.org If none of the three [top, bottom, height] are ‘auto’: If both ‘margin-top’ and ‘margin-bottom’ are ‘auto’, solve the equation under the extra constraint that the two margins get equal values.?AKA: center the block vertically

使用“完全居中”,有意遵照了标准margin: auto; 样式渲染的规定,所以应当在与标准兼容的各种浏览器中起作用。

对齐

容器内对齐

使用“完全居中”,就可以在一个设置了position: relative的容器中做到完全居中元素了! (居中例子,请前往英文原文查看)

CSS Code复制内容到剪贴板

.Center-Container {

position:relative;

}

.Absolute-Center {

width: 50%;

height: 50%;

overflow: auto;

margin:auto;

position:absolute;

top: 0;left: 0;bottombottom: 0;rightright: 0;

}

接下来的示例会假设已经包含了以下样式,并且以逐步添加样式的方式提供不同的特性。

在可视区域内居中

想要使内容区在可视区域内居中么?设置position: fixed样式,并设置一个较高的z-index值,就可以做到。

CSS Code复制内容到剪贴板

.Absolute-Center.is-Fixed {

position:fixed;

z-index: 999;

}

移动版Safari的说明:如果外面没有一层设置position: relative的容器,内容区会以整个文档的高度的中心点为基准居中,而不是以可视区域的高度中心点为基准居中。

偏移值

如果需要添加固定的标题,或者其他带偏移样式的元素,可以直接把类似top: 70px; 的样式写进内容区域的样式中。一旦声明了margin: auto; 的样式,内容块的top left bottom right的属性值也会同时计算进去。

如果想让内容块在贴近侧边的过程中保持水平居中,可以使用right: 0; left: auto; 让内容贴在右侧,或者使用left: 0; right: auto; 使内容贴在左侧。

CSS Code复制内容到剪贴板

.Absolute-Center.is-Fixed {

position:fixed;

z-index: 999;

}

带响应式

使用absolute的最大好处就是可以完美地使用带百分比的宽高样式!就算是min-width/max-width或者min-height/max-height也能够有如预期般的表现。

再进一步加上padding样式的话,absolute式的完全居中也丝毫不会破坏!

CSS Code复制内容到剪贴板

.Absolute-Center.is-Responsive {

width: 60%;

height: 60%;

min-width:200px;

max-width:400px;

padding:40px;

}

带溢出内容

内容区高度大于可视区域或者一个position: relative的容器,其内容可能会溢出容器,或被容器截断。只要内容区域没有超出容器(没有给内容容器预留padding的话,可以设置max-height: 100%;的样式),那么容器内就会产生滚动条。

CSS Code复制内容到剪贴板

.Absolute-Center.is-Overflow {

overflow: auto;

}

.

大小可调整

使用其他样式,或者使用JavaScript调整内容区的大小,也是不用手动重新计算的!如果设置了resize的样式,甚至可以让用户自行调节内容区域的大小。 “完全居中”法,无论内容区怎么改变大小,都会保持居中。

设置了min-/max- 开头的属性可以限制区块的大小而不用担心撑开容器。

CSS Code复制内容到剪贴板

.Absolute-Center.is-Resizable {

min-width: 20%;

max-width: 80%;

min-height: 20%;

max-height: 80%;

resize:both;

overflow:auto;

}

如果不设置resize: both的样式,可以设置transition样式平滑地在大小间切换。一定要记得设置overflow: auto样式,因为改变大小后的容器高宽很有可能会小于内容的高宽。 “完全居中”法是唯一一种能支持使用resize: both样式的方法。

使用注意:

需要设置max-width/max-height给内容区域留足够的空间,不然就有可能使容器溢出。

resize属性不支持移动版浏览器和IE8-10,如果用户体验很重要的话,请确保用户可以有其他替代方法来改变大小。

同时使用resize样式和transition会使用户在开始改变大小时产生等于transition效果时间等长的延时。

图像

图像也同样有效!提供相应的class,并指定样式 height: auto; ,就得到了一张随着容器改变大小的响应式图片。

请注意,height: auto; 样式虽然对图片有效,如果没有用到了后面介绍的‘可变高技巧’,则会导致普通内容区域伸长以适应容器长度。

浏览器很有可能是根据渲染结果填充了图像高度值,所以在测试过的浏览器中,margin: auto; 样式就像是声明了固定的高度值一般正常工作。

HTML:

XML/HTML Code复制内容到剪贴板

src="http://placekitten.com/g/500/200"alt=""/>

CSS:

CSS Code复制内容到剪贴板

.Absolute-Center.is-Image {

height: auto;

}

.Absolute-Center.is-Image img {

width: 100%;

height:auto;

}

可变高度

“完全居中”法的确需要声明容器高度,但是高度受max-height样式的影响,也可以是百分比。这非常适合响应式的方案,只需要设置好带溢出内容就行。

另一种替代方案是设置display: table样式居中,,不管内容的长度。这种方法会在一些浏览器中产生问题(主要是IE和Firefox)。我在ELL Creative的朋友Kalley写了一个基于Modernizr 的测试,可以用来检查浏览器是否支持这种居中方案。现在这种方法可以做到渐进增强。

注意要点: 这种方法会破坏浏览器兼容性,如果Modernizr测试不能满足你的需求,你可能需要考虑其他的实现方案。

与大小可调整技术是不兼容的

Firefox/IE8中使用display: table,内容区在垂直方向靠上,水平方向仍然居中。

IE9/10中使用display: table,内容区会跑到左上角。

移动版Safari中内容区是水平对齐的,但是如果使用了百分比的宽度,水平方向上会稍稍偏离中心。

Javascript:

JavaScript Code复制内容到剪贴板

/* Modernizr Test for Variable Height Content */

Modernizr.testStyles('#modernizr { display: table; height: 50px; width: 50px; margin: auto; position: absolute; top: 0; left: 0; bottom: 0; right: 0; }',function(elem, rule) {

Modernizr.addTest('absolutecentercontent', Math.round(window.innerHeight / 2 - 25) === elem.offsetTop);

});

CSS:

CSS Code复制内容到剪贴板

.absolutecentercontent .Absolute-Center.is-Variable {

display: table;

height: auto;

}

HTML中让整个效果居中,仅使用CSS做到完全居中的超级攻略相关推荐

  1. Python编程语言学习:列表与字典互转的几大方法集锦、从列表中按顺序循环抽走一个元素输出剩余元素之详细攻略

    Python编程语言学习:列表与字典互转的几大方法集锦.从列表中按顺序循环抽走一个元素输出剩余元素之详细攻略 目录 列表与字典互转的几大方法集锦 T1.基于两个列表利用zip函数来构造字典 <

  2. Python编程语言学习:python中与数字相关的函数(取整等)、案例应用之详细攻略

    Python编程语言学习:python中与数字相关的函数(取整等).案例应用之详细攻略 目录 python中与数字相关的函数 1.对小数进行向上取整 1.1.利用numpy库 1.2.利用math库

  3. CREO:CREO软件之工程图【插入页面】、【装配图出工程图】、【将视图转为绘制图元】、【工程图输入到CAD中去修改】的简介及其使用方法(图文教程)之详细攻略

    CREO:CREO软件之工程图[插入页面].[装配图出工程图].[将视图转为绘制图元].[工程图输入到CAD中去修改]的简介及其使用方法(图文教程)之详细攻略 目录

  4. 龙珠激斗获取服务器信息中,龙珠激斗战力220000贝吉塔快速获得途径攻略汇总详解...

    龙珠激斗战力220000贝吉塔如何获得?很多玩家都在提升自己的战斗力,下面为大家介绍的是关于战力220000贝吉塔的详细攻略指南,供大家参考. 开服3天的冲22万战斗力给4星塔无意是最大的福利,总之用 ...

  5. Cocos RenderTexture 橡皮擦效果 自定义画笔 最简单、最清晰的完全攻略

    版本:cocos2d-x 3.10     语言:C++ 今天开始看<Windows游戏编程大师技巧>,以后可能穿插着cocos,主要开始更这本书相关的内容. 其中一句话让我感触良深,游戏 ...

  6. linux终端中运行网银盾,Linux下使用Virtualbox安装 Windows 7 操作网银攻略

    作为一个Linux的爱好者,经过数次决心后放弃了双系统,只在自己的笔记本电脑里安装了Linux,坚持数月后发现网银是个问题,只能通过虚拟机来解决,现将安装使用中的要点同大家分享: 操作环境: 硬件:H ...

  7. 中龍鸿业安全可靠月薪2000元怎样理财?理财攻略

    月薪2000元除掉必要日子开支后,或许所剩不多了,但这不代表就没有理财的必要,关于一般出资者而言,经过合理的财富分配到达收支平衡是理财的首要方针. 贵州省铜仁市黔开产业投资发展集团有限责任公司(简称& ...

  8. HTML5中a袁术的属性,袁术使用方法,技巧,配合全攻略

    此贴3.2.1部分参考了"纸盒勇者"在我的帖子里面的回复,第六部分参考了"骷髅战车"的帖子,假如里面有小部分内容雷同了,希望以上两位吧友不要介意! 此贴为江户川 ...

  9. 服务器升级中怎么修改个性签名,王牌竞速个人签名怎么更改 签名更改攻略

    王牌竞速个人签名怎么更改名字是一个非常值得游戏玩家关注的游戏问题,在王牌竞速这款游戏当中,玩家可以根据自己的喜好,对个人的签名昵称等信息进行设置,也算是好友认识玩家的一张名片. 但是这个个人签名怎么更 ...

最新文章

  1. 最强 NLP 预训练模型库 PyTorch-Transformers 正式开源:支持 6 个预训练框架,27 个预训练模型...
  2. 7 series FPGA DSP48E介绍
  3. 手势识别之平移、缩放、长按、旋转、滑动
  4. 【互联网安全】DDoS攻防原理及实战
  5. 在RHEL上实现OpeenSSH
  6. xvhfeng的工作回忆总结(第二年)阅读手记
  7. C++中枚举的用法(比较全面)(转)
  8. Linux—编写shell脚本操作数据库执行sql
  9. 外媒:高通、微软和谷歌担忧英伟达收购Arm将损害竞争
  10. 研发部门之间利益之争何时休?如何休?
  11. 剑指offer——面试题58:二叉树的下一个结点
  12. FISCO BCOS Solidity 智能合约 批量插入新增数据
  13. python处理excel文件视频教程_(python处理excel文件视频教程)python怎么读取excel文件...
  14. ACOPTools:一步步帮你快速、高效构建多基因联合系统发育树
  15. html怎么设置字体为微软雅黑,css如何设置字体为微软雅黑
  16. 用python计算圆环面积公式_圆环的计算公式,一看就懂的
  17. layer添加元素 openlayer_OpenLayers使用点要素作为标记
  18. python安装pip之后镜像源配置
  19. Linux各目录及每个目录的详细介绍
  20. SQL Server 数据库表修改主键字段长度

热门文章

  1. laravel 验证码一直提示不正确的问题
  2. 河南省经济管理学校计算机系,2020年河南省经济管理学校招生简章
  3. 一对一语音直播系统源码——如何解决音视频直播技术难点
  4. 机械臂——arduino、marlin固件、printrun软件
  5. OneNote2016安装代码高亮插件
  6. 2020-12-03《Presto分布式SQL查询引擎——kkb笔记复习》
  7. RPA智能客服机器人,电商的好伙伴
  8. 大脑分区与功能简介汇总
  9. 【计算方法】雅克比迭代法-高斯赛德尔迭代法求解线性方程组(c语言实现)
  10. 用户画像 | 标签数据存储之MySQL真实应用