我有一排元素,我想使用 display: table-cell; 使文本垂直居中。有时一行会有一个活动状态,我需要在活动元素的顶部添加一个水平条。该条需要至少从行中删除一个像素。我为此使用了 :before 伪元素,它在 Chrome 中效果很好,但在 Firefox 中效果不佳,因为显示:table-cell;。
有什么解决办法吗?最好是没有javascript的。
在 Chrome 中工作,而不是在 Firefox 中:http: //jsfiddle.net/Danny_Joris/CYwUZ/
<div id="wrapper">
<div class="col1">col1 col1 col1</div>
<div class="col2">col2 col2 col2</div>
<div class="col3">col3 col3 col3</div>
</div>
#wrapper {
margin: 40px 0 0 0;
position: relative;
background: yellow;
display: inline-block;
}
#wrapper > div {
width: 33%;
display: table-cell;
vertical-align: middle;
height: 75px;
width: 60px;
border: 1px solid #ccc;
text-align: center;
position: relative;
}
.col2:before {
content: '';
position: absolute;
top: -7px;
height: 5px;
background: lightblue;
left: -1px;
right: -1px;
z-index: 50;
}