如何将 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);
}
我希望你能帮助我完成这项工作:
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);
}