我目前正在使用 FontAwesome,并且很难将图标在容器中垂直和水平居中。我尝试通过定位来做到这一点,但遇到了问题,因为图标大小不同。我基本上有水平的,并且正在尝试获得垂直的。
<div class='container'>
<div class='row'>
<div class='offset2 span6 loginContainer'>
<div class='row'>
<div class='login-icon'>
<i class='icon-user'></i>
</div>
<input type="text" placeholder="Email" />
</div>
<div class='row'>
<div class='login-icon'><i class=" icon-lock "></i></div>
<input type="password" class="" placeholder="Password" />
</div>
</div>
</div>
</div>
.login-icon{
font-size: 40px;
line-height: 40px;
background-color:black;
color:white;
width: 50px;
height: 50px;
}
.login-icon [class*='icon-']{
height: 50px;
width: 50px;
display: inline-block;
text-align: center;
vertical-align: baseline;
}
这就是您所需要的,无需包装纸:
.login-icon{
display:inline-block;
font-size: 40px;
line-height: 50px;
background-color:black;
color:white;
width: 50px;
height: 50px;
text-align: center;
vertical-align: bottom;
}
我使用变换来纠正偏移。它与救生圈等圆形图标配合得很好。
<span class="fa fa-life-ring"></span>
.fa {
transform: translateY(-4%);
}
使图标水平和垂直居中的最简单解决方案:
<div class="d-flex align-items-center justify-content-center">
<i class="fas fa-crosshairs fa-lg"></i>
</div>
所以我终于明白了(http://jsfiddle.net/ncapito/eYtU5/):
.centerWrapper:before {
content:'';
height: 100%;
display: inline-block;
vertical-align: middle;
}
.center {
display:inline-block;
vertical-align: middle;
}
<div class='row'>
<div class='login-icon'>
<div class='centerWrapper'>
<div class='center'> <i class='icon-user'></i></div>
</div>
</div>
<input type="text" placeholder="Email" />
</div>
我刚刚将 .login-icon [class*='icon-'] 的高度降低到 28px 这是小提琴:http://jsfiddle.net/mZHg7/
.login-icon [class*='icon-']{
height: 28px;
width: 50px;
display: inline-block;
text-align: center;
vertical-align: baseline;
}
您可以使用垂直变换:
<span class="fas fa-user" style="transform: translateY(-10%);"></span>
如果您使用 twitter Bootstrap,请将文本中心类添加到您的代码中。
<div class='login-icon'><i class="icon-lock text-center"></i></div>
我只是设法如何将图标居中并将它们制作为一个容器,而不是将它们放入一个容器中。
.fas {
position: relative;
color: #EEE;
font-size: 16px;
}
.fas:before {
position: absolute;
left: calc(50% - .5em);
top: calc(50% - .5em);
}
.fas.fa-icon {
width: 60px;
height: 60px;
color: white;
background-color: black;
}
我发现了一种更简单的方法..
为父元素添加
text-align:center;
属性,并添加 margin-top:50%;
为顶部添加边距。
根据问题:
.login-icon {
text-align: center;
}
.icon-lock {
margin-top: 50%;
}
稍后谢谢我。
就我而言,我能够使用网格将字体很棒的图标居中:
<div className="icon">
<FontAwesomeIcon icon={faLocationDot} />
</div>
.icon {
display: grid;
grid-template-columns: repeat(1, 100%);
place-items: center;
}