怎么在CSS中实现高度垂直居中
短信预约 -IT技能 免费直播动态提醒
这篇文章给大家介绍怎么在CSS中实现高度垂直居中,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。
<!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; } </style> </head> <body> <h2>垂直居中(table)</h2> <div class='container'> <table width="100%" height="100%"> <tr> <td align="center" valign="middle"> <img class="lazy" data-src="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg" /> </td> </tr> </table> </div> </body> </html>
好了,我们看其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;} </style> </head><body><h2>垂直居中</h2><div class="container"> </div></body></html>
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{ 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); } </style> </head> <body> <h2>垂直居中(CSS表达式)</h2> <div class="container"> <img class="lazy" data-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 { 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%; } </style> </head> <body> <h2>垂直居中(绝对定位)</h2> <div class="container"> <p> <img class="lazy" data-src="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg" /> </p> </div> </body></html>
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; } </style> <!--[if IE]><style type="text/css">i { display:inline-block; height:100%; vertical-align:middle }img { vertical-align:middle }</style><![endif]--> </head> <body> <h2>垂直居中(inline-block法)</h2> <div class="container"> <i></i> <img class="lazy" data-src="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg" /> </div> </body></html>
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> </head> <body> <h2>垂直居中(writing-mode法)</h2> <div class="container"> <span> <img class="lazy" data-src="http://images.cnblogs.com/cnblogs_com/rubylouvre/205314/r_iebug.jpg" /> </span> </div> </body></html>
css的选择器有哪些
css的选择器可以分为三大类,即id选择器、class选择器、标签选择器。它们之间可以有多种组合,有后代选择器、子选择器、伪类选择器、通用选择器、群组选择器等等
关于怎么在CSS中实现高度垂直居中就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341