1. 程式人生 > >CSS之未知高度img垂直居中

CSS之未知高度img垂直居中

效果如下:


測試程式碼如下:(能夠水平居中,通過text-align:center實現)

<style>
.box{ width:800px;height:600px;border:2px solid #000; text-align:center;}
</style>
</head>
<body>
<div class="box">
	<img src="bigptr.jpg" />
</div>

方案一:

在img標籤後邊新增一個span標籤,設定其顯示方式為inline-block,高度為100%,vertical-align屬性為middle;然後再給img標籤頁加上該vertical-align屬性即可。
<style>
.box{ width:800px;height:600px;border:2px solid #000; text-align:center;}
span{ display:inline-block; height:100%; vertical-align:middle;}
img{ vertical-align:middle;}
</style>
</head>
<body>
<div class="box">
	<img src="bigptr.jpg" /><span></span>
</div>
原理:   方案二: 通過display:table方式實現,在img外層新增一個span標籤,設定其display屬性為table-cell,同時vertical-align屬性為middle。但IE6,7不支援display:table屬性
<style>
.box{ width:800px;height:600px;border:2px solid #000; text-align:center;display: table;}
span{ display:table-cell; vertical-align:middle;}
</style>
</head>
<body>
<div class="box">
	<span><img src="bigptr.jpg" /></span>
</div>

在IE6,7下使用絕對定位(vertical-align:top是為了解決img標籤與span標籤的間距)
<style>
.box{ width:800px;height:600px;border:2px solid #000; text-align:center; display:table;position:relative; overflow:hidden;}
span{ display:table-cell; vertical-align:middle;*position:absolute;left:50%;top:50%;}
img{ *position:relative; vertical-align:top;left:-50%;top:-50%;}
</style>
</head>
<body>
<div class="box">
	<span><img src="bigptr.jpg" /></span>
</div>
原理: