之前老是想要一些元素垂直居中对齐,常常用line-height,但是对于图片来讲,line-height的表现并不理想,因此得用vertical-align:middle,如下是其用法:浏览器
在父元素定义了line-height的条件下,vertical-align的做用是让(inline/inline-block)子元素依据父元素的基点对齐
bash
数值详解:字体
1. 首先关于数值,见下面的示例:spa
.test{vertical-align:-2px;}
复制代码
元素相对于基线向下偏移两像素,这个经常用来修复单选框/复选框与12像素文字大小不对齐的问题。.net
2. 再者关于百分数值,这里的vertical-align,是相对于此标签继承的line-height值决定的。例如,以下示例代码:code
.test{vertical-align:-10%;}
复制代码
假设这里的.test的标签继承的行高是20px,则这里的所表明的实际值是:-10%*20px=-2px。 IE6/IE7浏览器下的vertical-align的百分比值不支持小数line-height。
cdn
。。。对象
只有一个元素属于inline或是inline-block(table-cell也能够理解为inline-block水平)水平,其身上的vertical-align属性才会起做用。
blog
<span class="box"> <span class="dot"> </span> 我是一段卡哇伊的文字</span>
.box{background:black; color:white; padding-left:20px;}
.dot{display:inline-block; width:4px; height:4px; background:white;vertical-align:top;}
复制代码
div父元素必须设置line-height,不然对其设置vertical-align无效,图片不会在绿色框里动
继承
<div class="outerbox">
<img src="C:\Users\Administrator\Desktop\test.jpg"/>
<span>这是外层元素的内部文字</span>
</div>
.outerbox{width:300px; line-height: 300px;font-size: 16px; }
.outerbox img{width: 30px; height:30px; vertical-align: bottom;}
.outerbox span{vertical-align: top;}
复制代码
对文字设置vertical-align:top 无效是由于文字继承了父元素的line-height,致使文字居中,要想vertical-align起做用,可在该元素上设置line-height小一些覆盖父元素
<div style="height:200px">
<img src="gallery4.jpg" style="width:50px;vertical-align:middle;">
<span style="vertical-align:middle">hahahahhah</span>
</div>
复制代码
只设文字的vertical-align,则文字的中线对齐图片底线
只设图片的vertical-align,则图片的中线与文字的基线对齐
两个的vertical-align都为middle,则两个的中线互相对齐
文章只为保存记录方便查询问题