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>
原理:

發佈了54 篇原創文章 · 獲贊 25 · 訪問量 4萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章