css 为什么给span加vertical-align: middle不起作用? 200

<styletype="text/css"><!--.div1{position:absolute;width:200px;height:115px;z-index:1;... <style type="text/css">
<!--
.div1{
position:absolute;
width:200px;
height:115px;
z-index:1;

}
.div1 span{vertical-align: middle;}
-->
</style>
</head>
<body>
<div class="div1">
<span>测试</span>
</div>
</body>
</html>
展开
 我来答
幸镶之9C
推荐于2018-02-27 · TA获得超过302个赞
知道答主
回答量:87
采纳率:0%
帮助的人:41.2万
展开全部
vertical-align是什么意思?先举个例子!

这句html元素中的文本为什么不能垂直居中。

<style>

span{ height:60px;vertical-align: middle; background-color: #1c93b7;

}

</style>
<span >
dddddddda</span>
我用浏览器试了一下,它的展示图如下:



vertical-align声明在很多中文文档中解释是“决定元素在垂直位置的显示”,它有下面几个参数baseline | sub | super | top | text-top | middle | bottom | text-bottom | 
baseline:与元素的基线对齐。
middle:与元素中部对齐。
sub:字下沉。
super:字上升。
text-top:文本顶部对齐。
text-bottom:文本底部对齐。
top:和本行位置最高元素对齐。
bottom:和本行位置最低元素对齐。

如果按照字面意思理解vertical-align:middle就应该是文字在元素的垂直位置的最中央,把入前面那个标签中,它的位置应该在一个height为60px的box的中央啊。但是事实上不是这样的。
如果这个vertical-align:middle用来定义一个单元格td,那么它和你想像的一样起作用,看看下面的例子
<tr>
<td style="height:80px;vertical-align:middle" onmouseover="this.style.verticalAlign='bottom'" 
onmouseout="this.style.verticalAlign='middle'">
text to align</td> 
</tr>
</table>

 

通过mouse over和out事件,我们动态的改变文字的垂直对齐位置,它确实按照你的做法工作。在msdn的文档中我发现它是可以做用于span元素的,但是没有详细解释vertical-align是怎么工作的。

后 来在《CSS20 Programmer’s Reference》(注1)查了查,Page12的The Inline Layout Model小节说明了行内布局的模型。这里有一个模型图。这段文字说明了在一行文字布局中,vertical-align是用来影响不同元素的对齐位置 的。



W3C官方对vertical-align做了下面的解释:
This property affects the vertical positioning inside a line box of the boxes generated by an inline-level element.

实 际上,一个Box中由很多行很多元素组成,vertical-align只作用于在同一行内的元素,它的垂直并不是相对于整个Box而言的。前面那个 span定义了一个60px的高度,但是这个span的Box中存在很多行,那段文本并不能对齐到span的中央。因此希望那段文本对齐span的中行, 需要给它定义一个line-height的属性,让line-height为60px,作用于一行的vertical-align就按你的想法工作了。

table的单元格,因为是一行内的元素,因此vertical-align按照我们的想法来工作,但是在span中并不是这样的。

注1、《CSS20 Programmer's Reference》,作者Eric A. Meyer,一本CSS20的编程参考手册。

 

如果帮到了你,请采纳我的答案好吗!

learneroner
高粉答主

推荐于2016-09-21 · 关注我不会让你失望
知道大有可为答主
回答量:1.1万
采纳率:91%
帮助的人:6352万
展开全部

vertical-align对一些特定显示样式(例如单元格显示方式:table-cell)的元素才会起作用。所以要实现上下垂直居中对齐,可以采用如下样式

display:table-cell;      /*按照单元格的样式显示元素*/
vertical-align:middle;   /*垂直居中对齐*/
  • 上面的设置方式相比设置line-height属性,可以兼容文字有多行的情形。

下面举例说明:

  1. 创建Html元素

    <div>
    <span>测试测试,即便是多行,我也还是垂直居中对齐的。</span>
    </div>
  2. 设置css样式

    div{ width:200px; height:115px; border:4px solid #ebcbbe; display:table-cell;vertical-align: middle;
  3. 观察显示效果

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
dsfl
2012-12-27
知道答主
回答量:3
采纳率:0%
帮助的人:3839
展开全部
改成 .div1 span{line-height: 115px;} 就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友dde64d5e7
2012-07-25 · TA获得超过2310个赞
知道小有建树答主
回答量:1430
采纳率:66%
帮助的人:1395万
展开全部
你用错了,如果要实现这种效果,看下面代码实现:
<style type="text/css">
.zxx_align_box_2{display:table-cell; width:550px; height:1.14em;
padding:0 0.1em; border:4px solid #beceeb; color:#069; font-size:10em;
vertical-align:middle;text-align:center;}
.zxx_align_box_2 span.zxx_align_word{display:inline-block;
font-size:0.1em; vertical-align:middle;}
</style>
</head>
<body>
<div class="zxx_align_box_2"><span class="zxx_align_word">这里显示多行文字。</span></div>
</body>
</html>
本回答被网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(2)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式