您所在的位置:小祥子 » 编程 » CSS » 正文

兼容各个浏览器的未知高度div垂直居中效果

时间:2015-07-10 编辑:我是代码努力 来源:CnBlogs

兼容各个浏览器的未知高度div垂直居中效果:
让div垂直居中与它的父对象中,并不像是让div在父元素中水平居中那么简单,只要简单的为此元素设置margin:0px auto即可,虽然将一些属性配合使用也可以将div垂直居中与父元素中,但是在某些浏览器中并不兼容,下面就介绍一种兼容各大浏览器的方式。
先看一段代码实例:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.51texiao.cn/" />
<title>蚂蚁部落</title> 
<style type="text/CSS"> 
.parent 
{ 
  width:200px; 
  height:200px; 
  background-color:green; 
  display:table-cell; 
  vertical-align:middle; 
} 
.children 
{ 
  background-color:red; 
  width:80px; 
  text-align:center; 
  margin:0px auto; 
} 
</style> 
</head> 
<body> 
<div class="parent"> 
  <div class="children">蚂蚁部落</div> 
</div> 
</body> 
</html>

以上代码在标准浏览器中运行一切正常,能够将子元素在父元素中垂直居中对齐,但是IE6和IE7就并非这么给力了,所以代码需要进行改造,以兼容IE6和IE7浏览器,但是如果仅仅是添加CSS兼容代码,不在结构上进行变化的话,很难实现兼容IE6和IE7,下面就对以上代码调整如下:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<meta name="author" content="http://www.51texiao.cn/" />
<title>蚂蚁部落</title> 
<style type="text/css"> 
.parent 
{ 
  width:200px; 
  height:200px; 
  background-color:green; 
  position:relative; 
  display:table; 
} 
.middle 
{ 
  display:table-cell; 
  vertical-align:middle; 
  *position:absolute; 
  *top:50%; 
  *left:50%; 
} 
.children 
{ 
  background-color:red; 
  width:80px; 
  text-align:center; 
  margin:0px auto; 
  *position:relative; 
  *top:-50%; 
  *left:-50%; 
} 
</style> 
</head> 
<body> 
<div class="parent"> 
<div class="middle"> 
   <div class="children">蚂蚁部落</div> 
</div> 
</div> 
</body> 
</html>

以上代码实现了将div垂直居中效果。此段代码大家不必看作为是第一段代码的修改版本,可以看做一个完全的新版本,下面就简单介绍一下次代码是如何实现此效果的:
一.实现思想:
由于IE6和IE7不支持display:table-cell和display:table,所以middle对象的高度和children对象的高度是一样的,当然如果children对象不设置宽度的话,它们尺寸是完全一样的。将middle对象在IE6和IE7中使用绝对定位,并且参考对象是parent对象,并且将它的top值设置为50%,这样middle对象的上边缘的位置恰好是parent对象垂直方位的中间位置。同样让children对象也使用定位,然后将它的top值设置为-50%,这样它的上移了middle的一半高度尺寸,这样children对象的中心位置也就位于parent对象的垂直方位的中间位置,这样就实现了children对象的垂直居中效果。这里可能有朋友会问,为什么其他标准浏览器不使用此方式,这是因为如果middle对象没有设置高度的话,设置的top属性并不能生效。以下图片是将middle背景颜色设置为蓝色后在IE6和IE7下运行效果图:

二.知识点说明:
1.星号(*)是为了兼容IE6和IE7浏览器。
2.parent对象中要添加display:table和middle对象中的display:table-cell相对应,否则在middle元素尺寸和内容自适应,而不是和parent元素的尺寸相同,这样就无法实现在标准浏览器中使children对象垂直居中了。

原文地址是:http://www.51texiao.cn/div_cssjiaocheng/2015/0501/503.html