垂直对齐图像和文本在表中

时间:2015-12-17 08:16:00

标签: html css html-table vertical-alignment

我在这里发现了一些文章和一些帖子,但没有一个是我正在寻找的东西,我试图修改它们但是没有按我的意愿工作。

我有1行和2列的表。第一列有一个带有图像的类 - url(数据)。另一列只有文本,我想将它们垂直对齐到中间。

HTML:

<div id="more-time2" class="very-small-text-size more-time " index="2" mode="Available" onclick="toggle(this.getAttribute('index'), this.getAttribute('mode'))">
    <table>
        <tr>
            <td id="arr-icon2" class="accordion_down"> </td>
            <td id="more-time-text2" class="more-time-button" index="2">more time</td>
        </tr>
    </table>
</div>

的CSS:

body
{
  direction:rtl;
}
.more-time {
        display: table;
        width: 100%;
        color: dodgerblue
    }

    td.accordion_down {
        background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAAB4AAAAUCAYAAACaq43EAAAABHNCSVQICAgIfAhkiAAAAaVJREFUSIm91c9KG1EUx/HvuRGzKVl2NxRnLD6DD1BoH2AOgWz6RxroypXgqiB0W+hGQSYiLoRm3FfotlAo3RUEF9USyEoQDIJlbDxdjC1VJ5mZNMnZzb3n3s/cxY8jS+0fc/DrEVOsKySZOeNBt8bRU8EWpwU7rOlilaQCdcNOpoEabEc6v+kANjXoCJWGQX/C6Lce1VcA7s9ipP5HkLUJumdGJYzVu7gBA/Tw3xiyPxnXLW3p3OHfr3+3YpU+zDaAzjhJQ95G6u/d+I3bTS31Tg0XGiTjQfnUw1+9vX4HTnH/C8jy/6N2ckm1HqvceUQmnOLBhsHu6Ch9odLYUa+btT8QBqhSaxp2MKL9Ok1Kdkne6eft4wVH/ytwr6hoyH5LgyfDeoa+GCCNgHtWFAU618kYWrkwQKT+nsG7vD6DxHBhS73TscAAPYIVQz4P75LlNBH5VRiOVZJLZsNBw8Rgt6XBRtH7CsMAO+p1s4aJYQdVas0yd5WCIXOYnF9BuK73z8vckxunQfWi/f2DYI+BeqTz78uenxkVTiPz82WkD0ujAL8B/TCG0encSKQAAAAASUVORK5CYII=');
        width: 12%;
        background-repeat: no-repeat;
        background-size: contain;
        display: table-cell;
        vertical-align: middle;
    }

    td.more-time-button {
        display: table-cell;
        vertical-align: middle;
        padding-right: 4%;
        width: 100%;
        padding: 0.25% 0;
    }

JsFiddle中添加了代码。

如何垂直对齐表格中的数据?

2 个答案:

答案 0 :(得分:6)

您的图片是背景图片,因此您需要使用background-position: center;

进行定位

这是handy article on CSS backgrounds

答案 1 :(得分:1)

对于背景,你应该使用背景位置和可选的两个参数作为xpos和ypos

backgroun-position:center center;

这里是JSFiddle链接检查出来

https://jsfiddle.net/amarmagar17/96rfgxmg/#&togetherjs=rLv9IUPm0G