У меня возникла эта странная проблема с моими шрифтами, удивительными значками. Я хотел, чтобы у моих значков была круглая граница. Я не хочу использовать border: 1px solid
, потому что граница значка будет выглядеть размытой. Я достиг этой гладкой границы с помощью «stacking method
» из шрифта удивительного, как описано hereFont-Awesome Проблема с укладкой значков в сафари
Так как мой шрифт 64px большой, это fa-circle-thin
иконки границы слишком толстая. Чтобы этого избежать, я использовал box-shadow
.
Моя проблема заключается в том, что моя граница значков не является однородной.
В хроме, граница немного толстая на левой стороне. (Как-то я не могу воспроизвести эту проблему в скрипкой/сниппет так, который можно пренебречь.)
, но в сафари , граница с правой стороны.
Как избавиться от этой проблемы? Я не хочу использовать -webkit-text-stroke
, так как он имеет ограниченную поддержку браузера. Любая помощь очень ценится :)
Вот мой код.
a{
text-decoration: none;
}
.social-block .fa {
font-size: 64px;
}
span.fa-stack {
width: 64px;
height: 64px;
}
.social-block .fa-stack-1x:before {
font-size: 24px;
vertical-align: top;
line-height: 64px;
}
.social-block .fa-stack-1x{
box-shadow: inset 0 0 0px 7px #fff;
position: absolute;
top: -1px;
}
.social-block a:hover .fa-stack-1x{
box-shadow: none;
}
.social-block a:hover .fa-stack-1x:before {
width: 50px;
height: 50px;
line-height: 50px;
left: 7px;
top: 7px;
position: absolute;
}
.social-block .fa {
color: #CC1E4A;
border-radius: 50%;
-webkit-transition: all ease .25s;
-moz-transition: all ease .25s;
-o-transition: all ease .25s;
transition: all ease .25s;
font-size: 64px;
}
.social-block a:hover .fa-circle-thin {
background: none;
}
.social-block a:hover .fa-stack-1x:before {
background: #CC1E4A;
display: block;
border-radius: 50%;
}
.social-block a:hover .fa-stack-1x {
color: #fff;
}
<link href="https://maxcdn.bootstrapcdn.com/font-awesome/4.5.0/css/font-awesome.min.css" rel="stylesheet"/>
<div class="social-block">
<a href="#">
<span class="fa-stack fa-lg">
<i class="fa fa-circle-thin fa-stack-2x"></i>
<i class="fa fa-facebook fa-stack-1x"></i>
</span>
</a>
<a href="#">
<span class="fa-stack fa-lg">
<i class="fa fa-circle-thin fa-stack-2x"></i>
<i class="fa fa-twitter fa-stack-1x"></i>
</span>
</a>
<a href="#">
<span class="fa-stack fa-lg">
<i class="fa fa-circle-thin fa-stack-2x"></i>
<i class="fa fa-linkedin fa-stack-1x"></i>
</span>
</a>
</div>
Неравномерность толщины границы также происходит в Firefox тоже. Я предложил ответ, используя border-radius вместо stacking, и он выглядит довольно хорошо, и не нужно * взламывать пиксели с абсолютной позицией. Выбор за вами, вы можете начать щедрость, если хотите больше внимания. – Stickers
@Pangloss Я действительно хотел толщину 1px. Но если я использую border: 1px solid, он будет выглядеть размытым. (общая проблема). Я думаю, что эта проблема с укладкой значка не имеет исправления. Переход с помощью метода border-radius. Спасибо за помощь. –
Я немного изменил код и добавил информацию для многословной версии шрифта, потрясающей, все обновленной в ответ, надеюсь, что это поможет. – Stickers