如何将 fontawesome 图标对齐到一条线的中间(已经尝试过现有的解决方案)

How to align fontawesome icon to the middle of a line (already tried the existing solutions)

我希望你能帮助我完成这项工作:

html代码:

        <div class="mainMenu">
            <ul>
                <li><a href="/">Home</a></li>
                <li><a href="/">Reviews <i class="fa fa-sort-desc"></i></a></li>
                <li><a href="/">News</a></li>
                <li><a href="/">Videos <i class="fa fa-sort-desc"></i></a></li>
                <li><a href="/">Forums</a></li>
            </ul>
        </div>

css代码:

.mainMenu {
    overflow: hidden;
    float: right;
}

.mainMenu ul {
    overflow: hidden;
    list-style: none;
    padding: 0;
    margin: 0;
}

.mainMenu li {
    float: left;
}

.mainMenu li a {
    line-height: 65px;
    padding: 0 10px;
    margin-left: 10px;
}

这是 jsfiddle 的 link: http://jsfiddle.net/shock/r5rd3v86/

如果您设置图标的垂直对齐方式,则可以对其应用负边距:

.fa { 
  vertical-align: middle;
  margin-top: -10px;
}

您可以通过将 position: relative 设置为包含超赞字体图标的 i 元素来精确控制位置。使用具有正值或负值的 top 偏移调整位置。

.mainMenu {
    overflow: hidden;
    float: left;
}
.mainMenu ul {
    overflow: hidden;
    list-style: none;
    padding: 0;
    margin: 0;
    border: 1px dotted gray;
}
.mainMenu li {
    float: left;
    border: 1px dotted gray;
}
.mainMenu li a {
    line-height: 65px;
    padding: 0 10px;
    margin-left: 10px;
    text-decoration: none;
    border: 1px dashed gray;
}
.mainMenu li a i {
    position: relative;
    top: -2px;
}
<link href="http://maxcdn.bootstrapcdn.com/font-awesome/4.3.0/css/font-awesome.min.css" rel="stylesheet"/>
<div class="mainMenu">
    <ul>
        <li><a href="/">Home</a></li>
        <li><a href="/">Reviews <i class="fa fa-sort-desc"></i></a></li>
        <li><a href="/">News</a></li>
        <li><a href="/">Videos <i class="fa fa-sort-desc"></i></a></li>
        <li><a href="/">Forums</a></li>
    </ul>
</div>

我不能这样评论: 你为什么使用 line-height: 65px;?在 jsfiddle 中,它就像 margin-top。尝试使用等于字体大小的行高并使用 vertical-align:middle

您也可以使用变换调整定位。

例如,使用以下 HTML:

<span class="fa fa-sort-asc"></span>
<span class="fa fa-sort-desc"></span>

将以下内容添加到您的样式表中:

.fa-sort-asc {
  transform: translateY(3px);
}

.fa-sort-desc {
  transform: translateY(-2px);
}