下面的代码(也可以作为JS Fiddle上的演示)没有将文本放置在中间,因为我理想的情况下希望它这样做。我找不到任何方法垂直中心的文本在一个div,甚至使用margin-top属性。我该怎么做呢?

<div id="column-content">
    <img src="http://i.stack.imgur.com/12qzO.png">
    <strong>1234</strong>
    yet another text content that should be centered vertically
</div>
#column-content {
    display: inline-block;
    border: 1px solid red;
    position:relative;
}
    
#column-content strong {
    color: #592102;
    font-size: 18px;
}

img {
    margin-top:-7px;
    vertical-align: middle;        
}

当前回答

接受的答案不适用于多行文本。

我更新了jsp,以显示CSS多行文本垂直对齐,如下所示:

<div id="column-content">
    <div>yet another text content that should be centered vertically</div>
</div>

#column-content {
    border: 1px solid red;
    height: 200px;
    width: 100px;
}
div {
    display: table-cell;
    vertical-align:middle;
    text-align: center;
}

它也适用于<br />在“yet another…”

其他回答

如果您需要多条线路,这是最简单的方法。将跨出的文本包装到另一个跨中,并使用line-height指定其高度。多行操作的诀窍是重置内跨度的行高。

<span class="textvalignmiddle"><span>YOUR TEXT HERE</span></span>
.textvalignmiddle {
    line-height: /* Set height */;
}

.textvalignmiddle > span {
    display: inline-block;
    vertical-align: middle;
    line-height: 1em; /* Set line height back to normal */
}

DEMO

当然外张成的空间可以是div之类的。

添加一个垂直对齐的CSS内容#column-content strong:

#column-content strong {
    ...
    vertical-align: middle;
}

请参见更新后的示例。

=== update ===

在另一个文本周围加上一个span和另一个垂直对齐:

HTML:

... <span>yet another text content that should be centered vertically</span> ...

CSS:

#column-content span {
    vertical-align: middle;
}

请参见下一个示例。

为您的文本内容创建一个容器,可能是一个span。

#列内容{ 显示:inline-block; } img { vertical-align:中间; } 跨度{ 显示:inline-block; vertical-align:中间; } /*为视觉目的*/ #列内容{ 边框:1px纯红色; 位置:相对; } < div id = "列内容" > < img src = " http://i.imgur.com/WxW4B.png " > < span > <强> 1234 < / >强 另一个文本内容应该垂直居中</span> < / div >

JSFiddle

试试这个:

HTML

<div><span>Text</span></div>

CSS

div {
    height: 100px;
}

span {
    height: 100px;
    display: table-cell;
    vertical-align: middle;
}

接受的答案不适用于多行文本。

我更新了jsp,以显示CSS多行文本垂直对齐,如下所示:

<div id="column-content">
    <div>yet another text content that should be centered vertically</div>
</div>

#column-content {
    border: 1px solid red;
    height: 200px;
    width: 100px;
}
div {
    display: table-cell;
    vertical-align:middle;
    text-align: center;
}

它也适用于<br />在“yet another…”