How to vertically align spans with text and image

2019-06-17 03:16发布

I have now been looking for hours (obviously not in the right place!)

Please consider this sample: http://jsfiddle.net/DYLs4/9/

<div id="wrapper">
    <span id="text24">Text 24</span>
    <span id="text12">Text 12</span>
    <span id="icon"></span>
</div>

css:

#text24{
    font-size:24px; color:#999;   
}
#text12{
    font-size:12px; color:#000;  
}
#icon{
    height:36px; width:36px;
    display:inline-block;
    background:url(some-icon.png);
}​

Result

What I'm trying to achieve is this:

  • Center vertically the text24 (relative to the image)
  • Align the bottom of text12 with bottom of text24
  • Make sure the whole thing work in IE6 -> chrome

Goal

Many thanks for your help!

4条回答
狗以群分
2楼-- · 2019-06-17 04:07

Final result

http://jsfiddle.net/rizwanabbasi/frsA5/

<div id="wrapper">
    <span id="text24">Text 24</span>
    <span id="text12">Text 12</span>
    <img src="http://www.adlittle.com/fileadmin/templates/images/rss_feed_icon.png" id="icon"/>
</div>

#wrapper{
    position:absolute; left:0;
}
#text24{
    font-size:24px; color:#999; font-weight:bold;
}
#text12{
    font-size:12px; color:#000; font-weight:bold; }
#icon{
    height:36px; width:36px;
    display:inline;
    vertical-align:middle;
    }
查看更多
唯我独甜
4楼-- · 2019-06-17 04:14

Add vertical-align: middle to your image.

EDIT

Per comments, this solution also requires display:inline-block;.

查看更多
劳资没心,怎么记你
5楼-- · 2019-06-17 04:17

I know most of designers hate use table for layout, but let me try anyway. You can use valign of table.

查看更多
登录 后发表回答