Sto avendo questo strano problema con le mie icone fantastiche font. Volevo che le mie icone avessero un bordo rotondo. Non voglio usare border: 1px solid
perché il bordo dell'icona apparirà sfocato. Ho raggiunto questo confine levigate dal "stacking method
" di font-impressionante come descritto hereFont-Awesome Icon stacking issue in safari
Dal momento che il mio carattere è 64px grande, questo fa-circle-thin
icone confine è troppo spessa. Per evitare che ho usato box-shadow
.
Il mio problema è che il mio bordo dell'icona non è uniforme.
in Chrome, di confine è un po 'di spessore sul lato sinistro. (In qualche modo non riesco a riprodurre questo problema in violino/frammento in modo che può essere trascurata.)
ma in Safari , il bordo è spesso sul lato destro.
Come sbarazzarsi di questo problema? Non voglio usare -webkit-text-stroke
in quanto ha un supporto browser limitato. Ogni aiuto è molto apprezzato :)
Ecco il mio codice.
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>
lo spessore del bordo irregolare si verifica anche in Firefox troppo. Ho suggerito una risposta usando border-radius invece di impilare, e sembra abbastanza buona, e non c'è bisogno di * hackerare * i pixel con la posizione assoluta. La scelta è tua, puoi iniziare una taglia se vuoi avere più attenzioni. – Stickers
@Pangloss In realtà volevo uno spessore di 1px. Ma se uso il bordo: 1 px solido, apparirà sfocato. (problema comune). Penso che questo problema di stacking delle icone non abbia una soluzione. Andando con il metodo border-radius. grazie dell'aiuto. –
Ho ottimizzato leggermente il codice e aggiunto le informazioni per la versione multi-peso del font fantastico, tutte aggiornate nella risposta, speriamo che sia d'aiuto. – Stickers