本文主要包含css未知高度垂直居中,高度尺图片,高度近视的危害图片,高度规图片,高度近视图片等相关知识,佚名 希望在学习及工作中可以帮助到您
标准浏览器还是将外部容器#box的显示模式设置为display:table-cell,IE6/IE7是利用在img标签的前面插入一对空标签的办法
但是实际在浏览器中实现起来的效果并不是很完美,由于各浏览器的解析都各不相同,所以在各浏览器都会有1px-3px的偏差。
方法一:
该方法是将外部容器的显示模式设置成display:table,img标签外部再嵌套一个span标签,并设置span的显示模式为display:table-cell,这样就可以很方便的使用vertical-align象表格元素那样对齐了,当然这只是在标准浏览器下,IE6/IE7还得使用定位。
HTML代码
- <div id="box">
- <span><img src="images/demo.jpg" alt="" /></span>
- </div>
CSS代码
- <style type="text/css">
- #box{
- width:500px;height:400px;
- display:table;
- text-align:center;
- border:1px solid #d3d3d3;background:#fff;
- }
- #box span{
- display:table-cell;
- vertical-align:middle;
- }
- #box img{
- border:1px solid #ccc;
- }
- </style>
- <!--[if lte IE 7]>
- <style type="text/css">
- #box{
- position:relative;
- overflow:hidden;
- }
- #box span{
- position:absolute;
- left:50%;top:50%;
- }
- #box img{
- position:relative;
- left:-50%;top:-50%;
- }
- </style>
- <![endif]-->
方法二:
方法二和方法一的实现的原理大同小异,结构也是相同的,方法一用的是条件注释,方法二就用的CSS Hack。
CSS代码
- #box{
- width:500px;height:400px;
- overflow:hidden;
- position:relative;
- display:table-cell;
- text-align:center;
- vertical-align:middle;