手机站
网通分站
电信主站
密 码:
用户名:
当前位置 : 主页>网页制作>css>列表

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

来源:互联网 作者:west263.com 时间:2008-02-23
西部数码-全国虚拟主机10强!40余项虚拟主机管理功能,全国领先!双线多线虚拟主机南北访问畅通无阻!免费赠送企业邮局,.CN域名,自助建站480元起,免费试用7天,满意再付款! P4主机租用799元/月.月付免压金!

  今天又在群中看到一些朋友问单行图片文字垂直居中问题了,于是写了这篇文章.

  这个问题是在做页面中经常会遇到的问题,首行我们先看一下最基础的的吧!

  以下选自(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了。

关键词:
【推荐给好友】【关闭】
最新五条评论
查看全部评论
评论总数 0 条
您的评论
用户名: 新注册) 密 码: 匿名:
·用户发表意见仅代表其个人意见,并且承担一切因发表内容引起的纠纷和责任
·本站管理人员有权在不通知用户的情况下删除不符合规定的评论信息或留做证据
·请客观的评价您所看到的资讯,提倡就事论事,杜绝漫骂和人身攻击等不文明行为

文章整理:西部数码--专业提供域名注册虚拟主机服务
http://www.west263.com
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!