box-lines
Non standard: Cette fonctionnalité n'est ni standard, ni en voie de standardisation. Ne l'utilisez pas pour des sites accessibles sur le Web : elle ne fonctionnera pas pour tout utilisateur. Il peut également y avoir d'importantes incompatibilités entre les implémentations et son comportement peut être modifié dans le futur.
Attention : Cette propriété fait partie de la première version du standard pour les boîtes flexibles (flexbox) et a été remplacée dans une version plus récente de la spécification. Voir la page Flexbox pour plus d'informations.
La propriété CSS box-lines
détermine si la boîte se compose d'une ou plusieurs rangées (des lignes pour les boîtes orientées horizontalement et des colonnes pour les boîtes orientées verticalement).
/* Valeurs avec un mot-clé */
box-lines: single;
box-lines: multiple;
/* Valeurs globales */
box-lines: inherit;
box-lines: initial;
box-lines: unset;
Par défaut, une boîte horizontale organisera ses éléments sur une seule ligne et une boîte verticale les organisera sur une seule colonne. On peut modifier ce comportement en utilisant box-lines
. La valeur par défaut est single
(ce qui correspond au cas expliqué avant) et les éléments qui ne peuvent être contenus dans cette ligne ou cette colonne dépasseront.
Si, au contraire, on utilise la valeur multiple
, la boîte pourra s'étendre sur plusieurs rangées (des lignes ou des colonnes) afin de contenir ses différents éléments fils. La boîte utilisera alors le moins de lignes ou de colonnes possibles et réduira les éléments à leur taille minimale si nécessaire.
Si les éléments fils d'une boîte horizontale ne rentrent pas dans une ligne après avoir été réduits à leur taille minimale, ils sont déplacés sur une nouvelle ligne jusqu'à ce que rien ne dépasse de la ligne précédente. Le procédé est répété autant de fois que nécessaire. Si une ligne contient un seul élément et que celui-ci est trop grand, ce dernier restera sur cette ligne et dépassera en dehors de la boîte. Les nouvelles lignes sont créées en dessous des premières lorsque la direction de la boîte est normal
, dans le sens inverse (reverse
) elles seront empilées les unes au-dessus des autres. La hauteur d'une ligne sera égale à la plus grande hauteur des éléments portés sur cette ligne. Aucun espace ne sera ajouté entre les lignes en dehors des marges décrites par les plus grands éléments. Lors du calcul de la hauteur, les éléments avec une marge dont la valeur calculée est auto
seront traités comme si la marge était nulle (0
).
On aura un fonctionnement analogue avec une disposition verticale.
Une fois que le nombre de rangées a été calculé, les éléments pour lesquels box-flex
a une valeur calculée différentes de 0
seront étirés afin de remplir les espaces restants sur les lignes. Ces étirements sont calculés de façon indépendante selon chaque ligne (notamment pour box-flex
et box-flex-group
). Il en va de même pour le regroupement des éléments sur une ligne avec la propriété box-pack
.
Syntaxe
Cette propriété est définie grâce à l'un des mots-clés suivants.
Valeurs
Définition formelle
Valeur initiale | single |
---|---|
Applicabilité | éléments de boîte |
Héritée | non |
Valeur calculée | comme spécifié |
Type d'animation | discrète |
Syntaxe formelle
Error: could not find syntax for this item
Exemples
Utilisation simple
Dans la version originale de la spécification, box-lines
permettait d'indiquer que les enfants du conteneur flexible devaient passer à la ligne. Cette propriété était uniquement implémentée par les navigateurs WebKit et avec un préfixe.
div {
display: box;
box-orient: horizontal;
box-lines: multiple;
}
La propriété équivalente qui la remplace est flex-wrap
.
Spécifications
Cette propriété ne fait partie d'aucun standard.
Compatibilité des navigateurs
BCD tables only load in the browser