您的位置:首页 > 其它

实现任意图片垂直居中的三种方法

2012-06-20 01:03 429 查看
在网站开发过程中,可能会有希望图片垂直居中的情况,而且,需要垂直居中的图片的高度也不确定,这就会给页面的布局带来一定的挑战。我总结了一下,曾经使用过的几种方法来使图片垂直居中,除了第一种方法只限于标准浏览器外,另外两种方法的兼容性还不错。

方法一:

将外部容器的显示模式设置成display:table,这个设置的意思不用多说了吧… img标签外部再嵌套一个span标签,并设置span的显示模式为display:table-cell,这样span内部的内容就相当于表格,可以很方便的使用vertical-align属性来对齐其中的内容了。

代码如下:

View Code

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>方法3 - 未知高度的图片垂直居中 - www.cleanthem.com</title>

<style type="text/css">
body {
height:100%;
}
#box{
width:500px;height:400px;
text-align:center;
border:1px solid #d3d3d3;background:#fff;
}
#box p{
width:500px;height:400px;
line-height:400px;  /* 行高等于高度 */
}

/* 兼容标准浏览器 */
#box p:before{
content:".";  /* 具体的值与垂直居中无关,尽可能的节省字符 */
margin-left:-5px; font-size:10px;  /* 修复居中的小BUG */
visibility:hidden;  /*设置成隐藏元素*/
}

#box p img{
*margin-top:expression((400 - this.height )/2);  /* CSS表达式用来兼容IE6/IE7 */
vertical-align:middle;
border:1px solid #ccc;
}
</style>

</head>

<body>
<div id="box">
<p><img src="images/demo_zl.png" alt="" /></p>
</div>

</body>
</html>


演示地址
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: