CSS图片垂直居中实现方法详解


方法一:利用定位
HTML结构如:

复制代码
代码如下:

<div class="box">
<a class="pic-wrap" href="#" target="_blank">
<img src="http://img01.taobaocdn.com/tps/i1/T1LeeNXodaXXXXXXXX-130-150.png">
</a>
</div>

CSS代码如:

复制代码
代码如下:

body {
margin: 0;
padding: 0;
font: 12px/1.5 tahoma,arial;
}
.box {
width: 220px;
height: 220px;
border: 1px solid #F30;
margin: 100px auto 0;
display: table;
}
.pic-wrap {
display: table-cell;
text-align: center;
vertical-align: middle;
}
/*主要针对IE6、7的hack*/
.box {
*position: relative;
}
.pic-wrap {
*width: 100%;
*position: absolute;
*top: 50%;
*left: 0;
/*继承自body的字体会影响到ie6,设置默认的windows系统字体*/
_font-family: sans-serif;
}
.pic-wrap img {
*position: relative;
*top: -50%;
*left: 0;
/*在ie中空文本节点有默认高度*/
vertical-align: middle\9;
/*在ie中,a标签中的img标签默认有蓝色边框*/
border: none\9;
}

方法二:
HTML结构同上;
CSS代码如:

复制代码
代码如下:

.box {
width: 220px;
height: 220px;
border: 1px solid #F30;
margin: 100px auto 0;
}
.pic-wrap {
display: table-cell;
vertical-align: middle;
width: 220px;
height: 220px;
text-align: center;
/*ie6、7不支持display:table-cell*/
*display: block;
*font-size: 192px; /*字体大小为height*0.783或者height/1.14,这里约为192px*/
_font-family: sans-serif; /*设置字体,否则在ie6下会有一个像素的偏差*/
}
.pic-wrap img {
border: none;
vertical-align: middle; /*由于ie下空文本节点有默认高度,所以设置*/
}

【注意,当在css中设置了body元素字体的话,那么方法二在ie7下会失效的】
最佳方法:
CSS代码如:

复制代码
代码如下:

body {
margin: 0;
padding: 0;
<SPAN style="COLOR: #ff6600">font: 12px/1.5 tahoma,arial;</SPAN>
}
.box {
width: 220px;
height: 220px;
border: 1px solid #F30;
margin: 100px auto 0;
}
.pic-wrap {
display: table-cell;
vertical-align: middle;
width: 220px;
height: 220px;
text-align: center;
/*ie6、7不支持display:table-cell*/
*display: block;
_font-size: 192px;
<SPAN style="COLOR: #ff6600">+line-height: 220px; /*设置ie7中空文本节点行高为220px*/</SPAN>
_font-family: sans-serif;
}
.pic-wrap img {
border: none;
vertical-align: middle\9; /*由于ie中有默认高度的空文本节点*/
}



相关阅读:
轻松修复Discuz!数据库
Wordpress博客首页中的每篇日志添加图片
sql 触发器使用例子
SEO的最高境界-SEO外链增加流量总结大全(收藏)
Community Server专题三:HttpModule
面向XHTML的IE条件注释
php中显示数组与对象的实现代码
CSS实例::nth-child和:nth-type-of的区别
Oracle存储过程返回数组的方法
如何为 Visual Studio 2005添加新的的 Team Foundation Server(TFS)
Linux 操作系统日志管理全攻略
一个修改Oracle数据库用户密码的小诀窍
MD5 Digest - VB, VBScript (ASP), and javascript versions
Windows Vista SP1 v658 安装完成的差异
快速导航
PHP MySQL HTML CSS JavaScript MSSQL AJAX .NET JSP Linux Mac ASP 服务器 SQL jQuery C# C++ java Android IOS oracle MongoDB SQLite wamp 交通频道 作文范文 只恨时光太匆匆 飘飘如雪 2011年县法院社会治安综合治理工作要点 我成了“小仙女” 小学六年级作文550字:090213周记 开学前的梦 修身洁行成语接龙 100字一年级作文精选 销售部2013年工作总结和2014年工作规划 第一次给小狗洗澡 习惯是一种瘾 《蓝精灵2》观后感精选4篇 2015年乡村医生年终述职报告 医院、社区岗区联创暨庆元旦文艺晚会串联词礼仪主持 西游记读后感作文 再见,再也不与你相见 公园游玩作文 小蜜蜂采“花蜜”250字 市场营销策划 故乡的河_关于描写小河的小学生作文700字 婚礼祝词--用于婚礼致辞 严密造句 年华作文150字 谁偷走了我的勇敢作文300字 区水利局上半年工作总结和下半年工作计划 轻轻地我来了 大话肩膀 如何抓好基层风气建设的几点认识 亮剑读后感200字 一年四季的校园作文700字 关于爱耳日的祝福语大全 我的家乡变美了(张津瑞) 美丽的春天作文750字 我办“古筝班”550字 儿童诗歌:荷韵 可怕的“战斗” 2013年三年级教学工作总结 习惯优秀才会优秀 2016超级演说家王帆演讲稿 做一个怎样的子女 保险业务员第一季度工作总结 师恩难忘谢谢老师对我的肯定650字 我的维拉斯 这样的生日快乐吗作文350字 2017学校体育工作计划小学 给父爱留些空隙作文 小学四年级作文400字:喝汤记 从化幽谷之旅 高一暑假安排指南 热浪滚滚水肆涝汹伏天织网速享智能 巨人的派对 2014大学生入党申请书谈话

Copyright © 2016 phpStudy |