CSS之未知高度img垂直居中
阿新 • • 發佈:2019-02-15
效果如下:
測試程式碼如下:(能夠水平居中,通過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屬性即可。原理: 方案二: 通過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;} 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>
<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>
原理: