Existe-t-il un moyen d'intégrer une bordure autour du texte comme l'image ci-dessous?
108
Utilisez plusieurs ombres de texte:
text-shadow: 2px 0 0 #fff, -2px 0 0 #fff, 0 2px 0 #fff, 0 -2px 0 #fff, 1px 1px #fff, -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff;
body {
font-family: sans-serif;
background: #222;
color: darkred;
}
h1 {
text-shadow: 2px 0 0 #fff, -2px 0 0 #fff, 0 2px 0 #fff, 0 -2px 0 #fff, 1px 1px #fff, -1px -1px 0 #fff, 1px -1px 0 #fff, -1px 1px 0 #fff;
}
<h1>test</h1>
Vous pouvez également utiliser un trait de texte, qui ne fonctionne que dans le kit Web:
-webkit-text-stroke-width: 2px;
-webkit-text-stroke-color: #fff;
body {
font-family: sans-serif;
background: #222;
color: darkred;
}
h1 {
-webkit-text-stroke-width: 2px;
-webkit-text-stroke-color: #fff;
}
<h1>test</h1>
Sûr. Vous pouvez utiliser CSS3
text-shadow
:Cependant, cela n'apparaîtra pas immédiatement dans tous les navigateurs. Cependant, l' utilisation d'une bibliothèque de scripts comme Modernizr aidera à bien faire les choses dans la plupart des navigateurs.
la source
Je n'aime pas beaucoup les solutions basées sur la multiplication des ombres de texte, ce n'est pas vraiment flexible, cela peut fonctionner pour un trait de 2 pixels où les directions à ajouter sont 8, mais avec seulement 3 pixels, les directions du trait sont devenues 16, et ainsi de suite. Pas vraiment confortable à gérer.
Le bon outil existe, c'est SVG
<text>
Le problème de support des navigateurs ne vaut rien dans ce cas, car l'utilisation de text-shadow a aussi son propre problème de support,filter: progid:DXImageTransform
peut être utilisé ou IE <10 mais ne fonctionne souvent pas comme prévu.Pour moi, la meilleure solution reste SVG avec une solution de secours en texte sans contour pour les navigateurs plus anciens:
Ce type d'approche fonctionne sur pratiquement toutes les versions de Chrome et Firefox, Safari depuis la version 3.04, Opera 8, IE 9
Comparé à
text-shadow
dont les supports sont: Chrome 4.0, FF 3.5, IE 10, Safari 4.0, Opera 9, il en résulte encore plus compatible.la source
la source
Ce qui suit couvrira tous les navigateurs à couvrir:
la source