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

html-css016

用CSS如何实现单行图片与文字垂直居中,第1张

vertical-align实现单行图片与文字垂直居中:

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了。

设置行高就可以了,行高值是根据你的高度来设的,如果你的高度是20px那么就设行高line-height:20px文字就上下居中了你现在高度是30px那么就设line-height:30px

.tt{

background-image:url(../images/index-title-rkjd.gif)

line-height:30px

height:30px

color : blue

font-family : Courier New

font-size : 13pt

}

一行文字可以通过line-height和高度相同来实现垂直中心对齐,图片的话可以给图片添加vertical-align:middle来实现,示例如下:

<style>

p{line-height:100pxhieght:100pxtext-align:center}

div{height:200pxtext-align:center}

div img{vertical-align:middlewidth:80pxheight:80px}

</style>

<p>示例文字</p>

<div><img src="图片"/></div>

如果是多行文字的话就得用到CSS的表格特性来做,示例如下:

<style>

.box { position: relative width: 200px height: 200px margin: 40px auto 0 auto background: #282d33 border: solid 1px #171717 box-shadow: inset 0 0 1px rgba(255, 255, 255, 0.4) color: #bbb }

.box .tag { position: absolute top: -11px left: 70px width: 60px height: 20px background: #1b1b1b border: solid 1px #171717 text-align: center }

/* IE6+ 支持图片和多行文字水平垂直居中 */

.ie_imgText { display: table width: 200px height: 200px text-align: center *position: relative }

.ie_imgText .cell { vertical-align: middle display: table-cell *position: absolute *top: 50% *left: 50% }

.ie_imgText .content { *position: relative *top: -50% *left: -50% }

</style>

<div class="box">

  <div class="ie_imgText">

    <div class="cell">

      <div class="content">

        <img src="图片" alt="">

        <p>文字文字</p>

        <p>文字文字文字</p>

      </div>

    </div>

  </div>

</div>