手机
当前位置:查字典教程网 >网页设计 > Div+Css教程 >任意图片实现垂直居中的三种方法(兼容性还不错)
任意图片实现垂直居中的三种方法(兼容性还不错)
摘要:在网站开发过程中,可能会有希望图片垂直居中的情况,而且,需要垂直居中的图片的高度也不确定,这就会给页面的布局带来一定的挑战。我总结了一下,曾...

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

方法一:

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

代码如下:

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>方法1 - 未知高度的图片垂直居中</title>

<style type="text/css">

body {

height:100%;

}

#box{

width:500px;height:400px;

display:table;

text-align:center;

border:1px solid #d3d3d3;background:#fff;

}

#box span{

display:table-cell;

vertical-align:middle;

}

#box img{

border:1px solid #ccc;

}

</style>

<>

</head>

<body>

<div id="box">

<span><img src="images/demo_zl.png" alt="" /></span>

</div>

</body>

</html>

方法二:

标准浏览器的情况还是和上面一样,不同的是针对IE6/IE7利用在img标签的前面插入一对空标签的办法。

代码如下:

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

<title>方法2 - 未知高度的图片垂直居中</title>

<style type="text/css">

body{

height:100%;

}

#box{

width:500px;

height:400px;

display:table-cell;

text-align:center;

vertical-align:middle;

border:1px solid #d3d3d3;

background:#fff;

}

#box img{

border:1px solid #ccc;

}

</style>

<>

</head>

<body>

<div id="box">

<i></i><img src="logo.png" alt="" />

</div>

</body>

</html>

方法三:

在img标签外包裹一个p标签,标准浏览器利用p标签的伪类属性:before来实现居中,另外,对于IE6/IE7使用了CSS表达式来实现兼容。

代码如下:

<html xmlns="http://www.w3.org/1999/xhtml">

<head>

<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />

<title>方法3 - 未知高度的图片垂直居中</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>

本人测试前两个没问题,第三个好像有问题

【任意图片实现垂直居中的三种方法(兼容性还不错)】相关文章:

css实现文字过长显示省略号的方法

CSS垂直居中和水平居中方法总结

DIV+CSS垂直居中一个浮动元素

CSS制作水平垂直居中对齐 多种方式各有千秋

CSS实现同一行的图片和文字垂直居中对齐的方法

垂直三栏布局拥有相同高度的方法

chrome居中但ie不居中的解决方法

CSS div居中的三种方法

给表格设置不重叠的边框(单线边框)的2种方法

CSS line-height行高上下居中垂直居中样式属性

精品推荐
分类导航