职业IT人-IT人生活圈

 找回密码
 成为会员
搜索
查看: 1278|回复: 0

小技巧:用CSS如何实现单行图片与文字垂直居中

[复制链接]
木头爱小猪 发表于 2007-8-15 10:31 | 显示全部楼层 |阅读模式
  今天又在群中看到一些朋友问单行图片文字垂直居中问题了,于是写了这篇文章.
  这个问题是在做页面中经常会遇到的问题,首行我们先看一下最基础的的吧!
  以下选自(CSS权威指南)
vertical-align
初始值: baseline(缺省值)
可否继承:否
适用于: 内联元素
说明:vertical-align:baseline使元素的基线同父元素的基线对齐.
警告:vertical-align不能影响表格单元中的内容的对齐,对于块元素中的内容也一样.  文字不多,但时常有人范错误,有人说我用了为什么没有效果呢?首行看一下他的代码.
.style{vertical-align:middle;.....}
HTML:<div class=\"style\"><img src=\"地址\" />...<div>  分析:从上面的代码可以看出错误就是把样式应用在块元素中了
  我们只需要改样式为
.style img{vertical-align:middle;.....}  如果STYLE中有其它如INPUT或其它内联元素可写成
.style img,.style.input{vertical-align:middle;.....}

.style *{vertical-align:middle;.....}
/*在不影响其它元素的情况下使用这个通配符*/  以上是在没有设置高度/行高的事情下,如果加入了高度和行高的事情下FF可以支持,IE6以下则不完全支持,看以下测试结果.(为了增加明显的效果对图片适当增加了高度)
  总结:对于单行图片文字垂直居中(有图片的情况下)
  1.当没有高度行高时,我们只要简单的对内联元素应用vertical-align:middle;就可以了.此外对于一个图片和文字的高度相差无几的,不用这个样式也是可以的.
  2.对于有行高或有行高+高度的,FF可以正确显示,ie6失效.所以也只能对IE6以下版本使用KACK了!,现在IE7已经改正了这个错误.
  3.对2补充一下,可以用不定高度,用上下补白的方法,这样就可以兼容IE6了。
您需要登录后才可以回帖 登录 | 成为会员

本版积分规则

QQ|手机版|小黑屋|网站帮助|职业IT人-IT人生活圈 ( 粤ICP备12053935号-1 )|网站地图
本站文章版权归原发布者及原出处所有。内容为作者个人观点,并不代表本站赞同其观点和对其真实性负责,本站只提供参考并不构成任何投资及应用建议。本站是信息平台,网站上部分文章为转载,并不用于任何商业目的,我们已经尽可能的对作者和来源进行了通告,但是能力有限或疏忽造成漏登,请及时联系我们,我们将根据著作权人的要求立即更正或者删除有关内容。

GMT+8, 2024-5-5 21:03 , Processed in 0.134138 second(s), 20 queries , Gzip On.

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表