La propriété break-before décrit la façon dont la page, la colonne ou la région se fragmente avant la boîte générée. S'il n'y a aucune boîte générée, la propriété est ignorée.

/* Valeurs de rupture génériques */
break-before: auto;
break-before: avoid;

/* Valeurs de rupture pour les pages */
break-before: avoid-page;
break-before: page;
break-before: always;
break-before: left;
break-before: right;
break-before: recto;
break-before: verso;

/* Valeurs de rupture pour les colonnes */
break-before: avoid-column;
break-before: column;

/* Valeurs de rupture pour les régions */
break-before: avoid-region;
break-before: region;

/* Valeurs globales */
break-before: inherit;
break-before: initial;
break-before: unset;

Chaque point de rupture éventuel (c'est-à-dire chaque frontière d'élément) est influencé par trois propriétés : la valeur de break-after de l'élément précédent, la valeur de break-before de l'élément suivant et la valeur de break-inside de l'élément englobant.

Pour déterminer si on a une rupture, on applique les règles suivantes :

  1. Si l'une des trois valeurs correspond à une rupture forcée (always, left, right, page, column ou region), cette valeur l'emporte. Si plusieurs valeurs décrivent une rupture forcée, c'est celle de l'élément qui apparaît le plus tard dans le flux qui est prise en compte (autrement dit, break-before l'emporte sur break-after qui l'emporte sur break-inside).
  2. Si l'une des trois valeurs correspond à une valeur visant à éviter une rupture (avoid, avoid-page, avoid-region, avoid-column), aucune rupture ne sera appliquée à cet endroit.

Une fois que les ruptures forcées ont été appliquées, le moteur peut ajouter des ruptures « douces » sauf aux endroits où les propriétés empêchent les ruptures.

Valeur initialeauto
Applicabilitééléments de type bloc
Héritéenon
Médiapaged
Valeur calculéecomme spécifié
Type d'animationdiscrète
Ordre canoniquel'ordre unique et non-ambigu défini par la grammaire formelle

Syntaxe

La propriété break-before se paramètre avec un des mots-clés définis ci-après.

Valeurs

Valeurs de rupture génériques

auto
Valeur initiale qui ne force ni n'interdit de rupture (de page, de colonne ou de région) avant la boîte.
avoid
Empêche toute rupture (de page, de colonne ou de région) avant la boîte.

Valeurs de rupture liées aux médias paginés

always
Force la rupture avant la boîte. Cette valeur est synonyme de page et a été conservée pour faciliter la transition depuis la propriété page-break-before (qui forme un sous-ensemble de cette propriété).
avoid-page
Empêche toute saut de page avant la boîte de l'élément.
page
Force un saut de page avant la boîte de l'élément
left
Force un ou deux saut de page avant la boîte de l'élément afin que la prochaine page soit une page gauche.
recto
Force un ou deux sauts de page avant la boîte de l'élément afin que la prochaine page soit une page recto (une page droite pour le sens de lecture gauche à droite et une page gauche pour le sens de lecture droite à gauche).
right
Force un ou deux saut de page avant la boîte de l'élément afin que la prochaine page soit une page droite.
verso
Force un ou deux sauts de page avant la boîte de l'élément afin que la prochaine page soit une page verso (une page gauche pour le sens de lecture gauche à droite et une page droite pour le sens de lecture droite à gauche).

Valeurs de ruptures relatives aux dispositions en colonnes

avoid-column
Empêche toute rupture de colonne avant la boîte de l'élément.
column
Force une rupture de colonne de page avant la boîte de l'élément.

Valeurs de ruptures relatives aux régions

region
Force une rupture de région avant la boîte de l'élément.
avoid-region
Empêche toute rupture de région avant la boîte de l'élément.

Syntaxe formelle

auto | avoid | avoid-page | page | left | right | recto | verso | avoid-column | column | avoid-region | region

Exemples

CSS

.exemple {
  -webkit-column-count: 4;
  -moz-column-count: 4;
  column-count: 4;
}

p {
  break-before: avoid-column;
  /* Pour Firefox : */
  page-break-before: avoid;
  /* Pour WebKit : */
  -webkit-column-break-before: avoid;
}

HTML

<div class="exemple">
  <p>« Mais alors, » pensa Alice, « ne serai-je donc
  jamais plus vieille que je ne le suis maintenant ?
  D’un côté cela aura ses avantages, ne jamais être
  une vieille femme. Mais alors avoir toujours des
  leçons à apprendre ! Oh, je n’aimerais pas cela du
  tout. »</p>
  <p>« Oh ! Alice, petite folle, » se répondit-elle.
  « Comment pourriez-vous apprendre des leçons ici ?
  Il y a à peine de la place pour vous, et il n’y en
  a pas du tout pour vos livres de leçons. »</p>
</div>

Résultat

Spécifications

Spécification État Commentaires
CSS Fragmentation Module Level 3
La définition de 'break-before' dans cette spécification.
Candidat au statut de recommandation Ajouts des mots-clés recto et verso. Le type de média pour cette propriété est passé de paged à visual. L'algorithme de rupture est précisé afin de gérer les différents types de rupture.
CSS Regions Module Level 1
La définition de 'break-before' dans cette spécification.
Version de travail La spécification étend la propriété pour gérer les sauts de région. Les mots-clés avoid-region et region sont ajoutés.
CSS Multi-column Layout Module
La définition de 'break-before' dans cette spécification.
Candidat au statut de recommandation Définition initiale. La spécification étend la propriété page-break-before de  CSS 2.1 afin de gérer les sauts de page ou de colonne.

Compatibilité des navigateurs

FonctionnalitéChromeEdgeFirefoxInternet ExplorerOperaSafari
Support simple Non Oui Non1011.1 — 12.1 Non
column and avoid-column Non Non Non1011.1 — 12.1 Non
recto and verso Non Non Non Non Non Non
region and avoid-region Non Non Non Non Non Non
FonctionnalitéAndroid webviewChrome for AndroidEdge mobileFirefox for AndroidOpera AndroidiOS SafariSamsung Internet
Support simple Non ? Oui Non ? Non ?
column and avoid-column Non ? Non Non ? Non ?
recto and verso Non ? Non Non Non Non ?
region and avoid-region Non ? Non Non Non Non ?

Étiquettes et contributeurs liés au document

Étiquettes : 
 Contributeurs à cette page : SphinxKnight
 Dernière mise à jour par : SphinxKnight,