font-family
Baseline Widely available
This feature is well established and works across many devices and browser versions. It’s been available across browsers since July 2015.
La propriété font-family
permet de définir une liste, ordonnée par priorité, de polices à utiliser pour mettre en forme le texte de l'élément ciblé.
Exemple interactif
Les valeurs sont séparées par des virgules, indiquant chacune une police alternative. Le moteur choisira la première valeur pour laquelle la police correspondante est installée sur l'ordinateur ou qui peut être téléchargée via la règle @ @font-face
définie.
Pour fixer font-family
et d'autres propriétés liées aux polices de caractères, on pourra utiliser la propriété raccourcie font
.
Les auteurs doivent toujours inclure une famille de police générique dans cette liste car il n'y a aucune certitude qu'une police donnée aura été installée sur l'ordinateur ni qu'elle pourra être téléchargée grâce à @font-face
. L'utilisation d'une famille de police générique permet au navigateur d'utiliser une police acceptable en recours si besoin.
Note :
La propriété font-family
définit une liste de police, ordonnée par priorité, de la plus haute à la plus basse. La sélection de la police ne se fait pas pour l'ensemble du texte mais caractère par caractère. Ainsi si une police ne dispose pas du caractère à représenter, ce sera la police suivante qui sera utilisée pour représenter le caractère. Pour Internet Explorer, cela ne fonctionne pas avec la version 6 et les version antérieures.
Les propriétés font-style
, font-variant
et font-size
permettront d'influencer le choix en fonction du style, de la variante ou de la taille disponible parmi les polices de la liste.
Syntaxe
/* Un nom de police suivi d'un nom de famille générique */
font-family: "Gill Sans Extrabold", sans-serif;
font-family: "Goudy Bookletter 1911", sans-serif;
/* Un nom de famille de polices générique */
font-family: serif;
font-family: sans-serif;
font-family: monospace;
font-family: cursive;
font-family: fantasy;
font-family: system-ui;
font-family: emoji;
font-family: math;
font-family: fangsong;
/* Valeurs globales */
font-family: inherit;
font-family: initial;
font-family: unset;
La propriété font-family
permet de lister différentes familles de police, séparées par des virgules. Chaque nom de famille est une valeur <family-name>
ou <generic-name>
.
Dans l'exemple suivant, on liste deux familles de police, la première utilise une valeur <family-name>
et la seconde utilise une valeur <generic-name>
:
font-family:
Gill Sans Extrabold,
sans-serif;
Valeurs
<family-name>
-
Le nom d'une famille de polices ; par exemple « Times » ou « Helvetica » sont des noms de famille de polices. Les noms de familles qui comportent des blancs doivent être encadrées par des doubles quotes (").
<generic-name>
-
Les noms de famille génériques sont utilisés comme mécanisme de secours pour conserver l'intention de mise en forme de l'auteur lorsqu'aucune des polices indiquées n'est disponible. Les noms de famille génériques sont des mots-clés et ne doivent pas être encadrés par des doubles quotes. Un nom de famille générique devrait être utilisé comme dernier élément de la liste des noms. Les mots-clés suivants sont définis :
serif
-
Les caractères possèdent des empattements. Voici des exemples de polices avec empattement : Lucida Bright, Lucida Fax, Palatino, "Palatino Linotype", Palladio, "URW Palladio", serif.
sans-serif
-
Les caractères n'ont pas d'empattement, leurs extrémités sont anguleuses. Voici des exemples de polices correspondantes : "Open Sans", "Fira Sans", "Lucida Sans", "Lucida Sans Unicode", "Trebuchet MS", "Liberation Sans", "Nimbus Sans L", sans-serif.
monospace
-
Tous les caractères mesurent la même largeur, on dit que la police est à chasse fixe. Les polices "Fira Mono", "DejaVu Sans Mono", Menlo, Consolas, "Liberation Mono", Monaco, "Lucida Console", monospace sont à chasse fixe.
cursive
-
Les caractères des polices cursives possèdent des extrémités permettant de les joindre les uns aux autres, partiellement ou complètement. Cela donne un résultat semblable à l'écriture manuelle au crayon plutôt qu'à des caractères d'imprimerie. Voici quelques exemples de polices cursives : "Brush Script MT", "Brush Script Std", "Lucida Calligraphy", "Lucida Handwriting", "Apple Chancery", cursive.
fantasy
-
Les polices fantaisie sont des polices décoratives pour lesquelles les caractères sont représentées de façon légère. Les polices suivantes sont des exemples de cette famille : Papyrus, Herculanum, Party LET, Curlz MT, Harrington, fantasy.
system-ui
-
Les glyphes utilisés sont ceux de l'interface utilisateur par défaut pour le système d'exploitation de la plateforme. Les variantes typographiques différant grandement d'une région à l'autre, cette famille générique est utilisée pour les polices qui ne correspondent pas aux autres familles génériques.
math
-
Une police utilisée pour les mise en forme relatives aux mathématiques comme les indices, les exposants, les accolades sur plusieurs lignes, etc.
emoji
-
Une police conçue spécifiquement pour l'affichage des emoji.
fangsong
-
Un style de caractères chinois particulier se situant entre le style serif Song et la forme cursive Kai. Ce style est généralement utilisé pour les documents officiels du gouvernement.
Validité des noms de famille
Les noms de famille de polices doivent être encadrés par des doubles ou doivent former une série d'un ou plusieurs identifiants valides. Cela signifie que les signes de ponctuation et les chiffres débutant chaque fragment doivent être échappés pour les noms de famille qui ne sont pas encadrés par des quotes.
Les déclarations suivantes sont valides :
font-family: "Gill Sans Extrabold", sans-serif;
font-family: "Goudy Bookletter 1911", sans-serif;
Et ces déclarations sont invalides :
font-family:
Goudy Bookletter 1911,
sans-serif;
font-family: Red/Black, sans-serif;
font-family:
"Lucida" Grande,
sans-serif;
font-family: Ahem!, sans-serif;
font-family:
test @foo,
sans-serif;
font-family: #POUND, sans-serif;
font-family:
Hawaii 5-0,
sans-serif;
Définition formelle
Valeur initiale | dépend de l'agent utilisateur |
---|---|
Applicabilité | all elements and text. S'applique aussi à ::first-letter et ::first-line . |
Héritée | oui |
Valeur calculée | comme spécifié |
Type d'animation | discrète |
Syntaxe formelle
font-family =
[ <family-name> | <generic-family> ]#
<family-name> =
<string> |
<custom-ident>+
<generic-family> =
<generic-script-specific> |
<generic-complete> |
<generic-incomplete>
<generic-script-specific> =
generic( kai ) |
generic( fangsong ) |
generic( nastaliq )
<generic-complete> =
serif |
sans-serif |
system-ui |
cursive |
fantasy |
math |
monospace
<generic-incomplete> =
ui-serif |
ui-sans-serif |
ui-monospace |
ui-rounded
Exemples
CSS
.exempleserif {
font-family: Times, "Times New Roman", Georgia, serif;
}
.exemplesansserif {
font-family: Verdana, Arial, Helvetica, sans-serif;
}
.exemplemonospace {
font-family: "Lucida Console", Courier, monospace;
}
.exemplecursive {
font-family: cursive;
}
.exemplefantasy {
font-family: fantasy;
}
.exempleemoji {
font-family: emoji;
}
.exemplemath {
font-family: math;
}
.exemplefangsong {
font-family: fangsong;
}
HTML
<div class="exempleserif">
Voici un exemple de police avec empattement (serif).
</div>
<div class="exemplesansserif">
Voici un exemple de police sans empattement (sans-serif).
</div>
<div class="exemplemonospace">
Voici un exemple de police à chasse fixe (monospace).
</div>
<div class="exemplecursive">Voici un exemple de police cursive.</div>
<div class="exemplefantasy">Voici un exemple de police fantaisie.</div>
<div class="exemplemath">Voici un exemple de police mathématique.</div>
<div class="exempleemoji">Voici un exemple de police emoji.</div>
<div class="exemplefangsong">Voici un exemple de police fangsong.</div>
Résultat
Spécifications
Specification |
---|
CSS Fonts Module Level 4 # generic-font-families |
CSS Fonts Module Level 4 # font-family-prop |
Compatibilité des navigateurs
BCD tables only load in the browser