嵌入式的学习

  最近,对于如何让未知尺寸大小的图片在容器中垂直居中这个问题,大家表现出关注度非常高。

  首先,我们不要去追究是否有这样做的必要,因为有的时候图片是从数据库读取的,可能大小不一,这时候为了不让图片大小不一而破坏了页面的美观性,其实就有必要这么做了。

  总的来说,会有几种方案可以用来做这件事。这里,我只写一种个人认为较为简单和易于理解的方法。

  [预览地址:暂未上传]

CSS部分:

.outer {
 border:1px solid #f00;
 display:table;
 width:300px;
 height:300px;
 text-align:center;
 float:left;
 margin-right:20px;
 #position:relative;
}
.mid {
 display:table-cell;
 vertical-align:middle;
 #position:absolute;
 #top:50%;
}
.mid img {
 #position:relative;
 #top:-50%;
 #left:-50%;
 vertical-align:middle;
}

XHTML部分:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
 "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<meta http-equiv="Content-Language" content="gb2312" />
<title>test</title>
<meta name="Author" content="Doyoe(飘零雾雨), edzmaster@gmail.com" />
</head>
<body>
<h1>Vertical Centering in CSS</h1>
<div class="outer">
 <div class="mid"><img src="1.gif" alt="test1" title="test1" /></div>
</div>
<div class="outer">
 <div class="mid"><img src="2.gif" alt="test2" title="test2" /></div>
</div>
</body>
</html> 

  假设上面XHTML中的图片1.gif和2.gif就是从数据库读取出来的(可以使用本地机器上现有的图片测试),它们的尺寸规格不同。我们可以看到的效果为:它们都在容器outer里垂直居中了。

  其实对于支持display:table | table-cell的浏览器来说,远不需要如此多的步骤就可以实现未知高度的图片的垂直居中了。而CSS部分里的Hack都是为不支持这些属性的IE准备的。为了测试,可以将以上的Hack部分都注释掉,然后看看效果。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值