CSS未知高度垂直居中

最近群里这个问题比较热门,决定把我收藏的方法分享大家。在开始时,我们先看一下万能的 table 实现。

<!doctype html> <html lang="en"> <head> <meta charset="utf-8" /> <meta content="IE=8" http-equiv="X-UA-Compatible"/> <title> 司徒正美 CSS 垂直居中 </title> <style type="text/css"> .container{ width:500px;/* 装饰 */ height:500px; background:#B9D6FF; border: 1px solid #CCC; } <pre><code>&lt;/style&gt; </code></pre> <p></head><br /> <body><br /> <h1> 垂直居中(table)</h1><br /> <div class='container'><br /> <table width="100%" height="100%"><br /> <tr><br /> <td align="center" valign="middle"><br /> <img src="<a href="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg">http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg</a>" /><br /> </td><br /> </tr><br /> </table><br /> </div></p> <p></body><br /> </html><br />

运行代码

好了,我们看其 CSS 实现。凡是 table 能做到的,CSS 都能做的,但各浏览器在 CSS 的差异比较大,因此要兼容它们难度很大。这涉及许多细节,各种流啊,display 的表现效果与 CSS hack,IE 早些年搞了大堆的私有属性,这也有待我们深一步挖掘。我们先看最简单的实现,背景图片法——

背景图片法

<!doctype html> <html> <head> <title> 司徒正美 CSS 垂直居中 </title> <style type="text/css"> .container { width:500px; height:500px; line-height:500px; background:#B9D6FF url(http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg) no-repeat center center; border:1px solid #f00; text-align: center; } <p></style></p> <p></head><br /> <body><br /> <h1> 垂直居中(背景图片法)</h1><br /> <div class="container"></p> <p></div><br /> </body><br /> </html><br />

运行代码

CSS 表达式法

<html lang="en"> <head> <meta charset="utf-8" /> <meta content="IE=8" http-equiv="X-UA-Compatible"/> <title> 司徒正美 CSS 垂直居中 </title> <style type="text/css"> .container{ /*IE8 与标准游览器垂直对齐 */ display: table-cell; vertical-align:middle; width:500px;/* 装饰 */ height:500px; background:#B9D6FF; border: 1px solid #CCC; } .container img{ display:block;/* 让其具备盒子模型 */ margin:0 auto; text-align:center; margin-top:expression((500 - this.height)/2);/* 让 IE567 垂直对齐 */} </style> </head> <body> <h1> 垂直居中(CSS 表达式)</h1> <div class="container"> <img src="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg" /> </div> </body> </html>

运行代码

绝对定位法

<!doctype html> <html lang="en"> <head> <meta charset="utf-8" /> <meta content="IE=8" http-equiv="X-UA-Compatible"/> <title> 司徒正美 CSS 垂直居中 </title> <style type="text/css"> div { /*IE8 与标准游览器垂直对齐 */ display:table-cell; vertical-align:middle; overflow:hidden; position:relative; text-align:center; width:500px;/* 装饰 */ height:500px; border:1px solid #ccc; background:#B9D6FF; } div p { +position:absolute; top:50% } img { +position:relative; top:-50%; left:-50%; } <pre><code>&lt;/style&gt; </code></pre> <p></head><br /> <body><br /> <h1> 垂直居中 (绝对定位)</h1><br /> <div class="container"><br /> <p><br /> <img src="<a href="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg">http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg</a>" /><br /> </p><br /> </div><br /> </body><br /> </html><br />

运行代码

display:inline-block 法

<!doctype html> <html lang="en"> <head> <meta charset="utf-8" /> <meta content="IE=8" http-equiv="X-UA-Compatible"/> <title> 司徒正美 CSS 垂直居中 </title> <style type="text/css"> div { display:table-cell; vertical-align:middle; text-align:center; width:500px; height:500px; background:#B9D6FF; border: 1px solid #CCC; } <pre><code>&lt;/style&gt; &lt;!--[if IE]&gt; </code></pre> <p><style type="text/css"><br /> i {<br /> display:inline-block;<br /> height:100%;<br /> vertical-align:middle<br /> }<br /> img {<br /> vertical-align:middle<br /> }<br /> </style><br /> <![endif]--></p> <p></head><br /> <body><br /> <h1> 垂直居中 (display:inline-block 法)</h1><br /> <div class="container"><br /> <i></i><br /> <img src="<a href="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg">http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg</a>" /><br /> </div><br /> </body><br /> </html><br />

运行代码

writing-mode 法

<!doctype html> <html lang="en"> <head> <meta charset="utf-8" /> <meta content="IE=8" http-equiv="X-UA-Compatible"/> <title> 司徒正美 CSS 垂直居中 </title> <style type="text/css"> div{ width:500px; height:500px; line-height:500px; text-align:center; background:#B9D6FF; border:1px solid #f00; } div span{ height:100%\9; writing-mode:tb-rl\9; } div img{vertical-align:middle} </style> <p></head><br /> <body><br /> <h1> 垂直居中 (writing-mode)</h1><br /> <div class="container"><br /> <span><br /> <img src="<a href="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg">http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg</a>" /><br /> </span><br /> </div><br /> </body><br /> </html><br />

运行代码

记得淘宝也搞一个 font-size 法,但我觉得上下差异比较大,就不收录了。怿飞的博客亦提到过一韩国人有个巧妙的实现,但日久链接失效了,谁收藏了也请提供一下。


新发现的逆天方法,使用 button 标签做容器

SVG 大法

如果您觉得此文有帮助,可以打赏点钱给我支付宝 1669866773@qq.com ,或扫描二维码