本文主要包含图片,垂直居中等相关知识,佚名  希望在学习及工作中可以帮助到您
  标准浏览器还是将外部容器#box的显示模式设置为display:table-cell,IE6/IE7是利用在img标签的前面插入一对空标签的办法
但是实际在浏览器中实现起来的效果并不是很完美,由于各浏览器的解析都各不相同,所以在各浏览器都会有1px-3px的偏差。
方法一:
该方法是将外部容器的显示模式设置成display:table,img标签外部再嵌套一个span标签,并设置span的显示模式为display:table-cell,这样就可以很方便的使用vertical-align象表格元素那样对齐了,当然这只是在标准浏览器下,IE6/IE7还得使用定位。
HTML代码
 
- <div id="box">
 - <span><img src="images/demo.jpg" alt="" /></span>
 - </div>
 
CSS代码
 
- <style type="text/css">
 - #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>
 - <!--[if lte IE 7]>
 - <style type="text/css">
 - #box{
 - position:relative;
 - overflow:hidden;
 - }
 - #box span{
 - position:absolute;
 - left:50%;top:50%;
 - }
 - #box img{
 - position:relative;
 - left:-50%;top:-50%;
 - }
 - </style>
 - <![endif]-->
 
方法二:
方法二和方法一的实现的原理大同小异,结构也是相同的,方法一用的是条件注释,方法二就用的CSS Hack。
CSS代码
 
- #box{
 - width:500px;height:400px;
 - overflow:hidden;
 - position:relative;
 - display:table-cell;
 - text-align:center;
 - vertical-align:middle;
 - border:
 

