Passer au contenu principal

ColumnsLayout

Ouvrir dans ChatGPT
Shadow dwc-columns-layout 24.10
Java API

Le composant ColumnsLayout dans webforJ permet aux développeurs de créer des mises en page en utilisant une disposition verticale flexible et réactive. Cette mise en page offre des colonnes dynamiques qui s'ajustent en fonction de la largeur disponible. Ce composant simplifie la création de mises en page multi-colonnes en gérant automatiquement les points de rupture et les alignements.

Dispositions horizontales

Ceci peut être utilisé à la place de, ou en combinaison avec, le composant FlexLayout - un outil tout aussi puissant pour les dispositions horizontales.

Bases

Lors de sa première instanciation, le ColumnsLayout utilise deux colonnes pour afficher les éléments ajoutés à la mise en page. Par défaut, il occupe toute la largeur de ses éléments parents et grandit au besoin pour s'adapter à un contenu supplémentaire. L'affichage des éléments ajoutés peut être affiné grâce à l'utilisation des paramètres Breakpoint et Alignment, qui seront discutés en détail dans les sections suivantes.

Afficher le code

Points de rupture

Au cœur de la conception, le ColumnsLayout est conçu pour fournir un système fluide, de type grille, qui s'adapte à la largeur de son conteneur parent. Contrairement aux systèmes de grille fixes traditionnels, cette disposition permet aux développeurs de spécifier un nombre de colonnes à une largeur donnée et calcule dynamiquement le nombre de colonnes affichées en fonction des objets Breakpoint définis.

Cela permet à un ColumnsLayout de s'adapter en douceur d'un espace plus restreint sur les petits écrans à une zone plus large sur les grands écrans, offrant ainsi un design réactif à un développeur sans avoir besoin d'implémentation personnalisée.

Comprendre un Breakpoint

Un Breakpoint peut être spécifié en utilisant la classe Breakpoint, qui prend trois paramètres :

  1. Nom (facultatif) : Nommer un point de rupture vous permet de le référencer dans des configurations futures.

  2. Largeur minimum : Chaque point de rupture a une plage spécifique qui détermine quand sa mise en page est appliquée. La largeur minimum est définie explicitement, et le point de rupture suivant détermine la largeur maximum, si elle existe. Vous pouvez utiliser un entier pour définir la largeur minimale en pixels ou utiliser une String pour spécifier d'autres unités telles que vw, %, ou em.

  3. Nombre de colonnes : Spécifiez combien de colonnes un point de rupture doit avoir avec cet entier.

Évaluation de Breakpoint

Les points de rupture sont évalués dans l'ordre croissant de la largeur, ce qui signifie que la mise en page utilisera le premier point de rupture correspondant.

Application des points de rupture

Les points de rupture sont appliqués à un ColumnsLayout de deux manières : lors de la construction, ou dans une List en utilisant la méthode setBreakpoints() :

ColumnsLayout layout = new ColumnsLayout();

List<Breakpoint> breakpoints = List.of(
// Une colonne à des largeurs >= 0px
new Breakpoint(0, 1),
// Deux colonnes à des largeurs >= 600px
new Breakpoint(600, 2),
// Quatre colonnes à des largeurs >= 1200px
new Breakpoint(1200, 4));

layout.setBreakpoints(breakpoints);

La démonstration ci-dessous montre un exemple de définition de plusieurs points de rupture lors de la construction, utilisant des points de rupture pour configurer le Span d'un composant, et démontre les capacités de redimensionnement du ColumnsLayout lorsque l'application est redimensionnée :

Afficher le code

Span de colonne et spans par Breakpoint

Les spans de colonne dans ColumnsLayout vous permettent de contrôler combien de colonnes un élément occupe, vous donnant plus de contrôle sur l'apparence de votre mise en page à différentes largeurs. Cela est particulièrement utile lorsque vous avez besoin que certains éléments prennent plus ou moins de place en fonction de la taille de l'écran ou des exigences de conception.

Gestion des spans de colonnes

Par défaut, chaque élément dans le ColumnsLayout occupe exactement une colonne. Cependant, vous pouvez personnaliser ce comportement en définissant le span de colonne pour des éléments individuels. Un span spécifie le nombre de colonnes qu'un élément doit occuper.

Button button = new Button("Cliquez moi");
layout.addComponent(button);
// L'élément occupe deux colonnes
layout.setSpan(button, 2);

Dans l'exemple ci-dessus, le bouton occupe deux colonnes au lieu de la colonne par défaut. La méthode setSpan() vous permet de spécifier combien de colonnes un composant doit occuper dans la mise en page.

Ajustement des spans de colonnes avec des points de rupture

Vous pouvez également ajuster les spans de colonnes dynamiquement en fonction des points de rupture. Cette fonctionnalité est utile lorsque vous souhaitez qu'un élément s'étende sur différents nombres de colonnes en fonction de la taille de l'écran. Par exemple, vous pouvez vouloir qu'un élément occupe une seule colonne sur des appareils mobiles, mais qu'il s'étende sur plusieurs colonnes sur des écrans plus grands.

TextField email = new TextField("Email");
//...
List.of(
new ColumnsLayout.Breakpoint("default", 0 , 1),
new ColumnsLayout.Breakpoint("small", "20em", 1),
new ColumnsLayout.Breakpoint("medium", "40em", 2),
new ColumnsLayout.Breakpoint("large", "60em", 3)
)
//...
//le champ email s'étendra sur deux colonnes lorsque le point de rupture moyen sera actif
columnsLayout.setSpan(email, "medium", 2);
//...

Ce niveau de personnalisation garantit que votre mise en page reste réactive et correctement structurée sur différents appareils.

Placer des éléments dans les colonnes

ColumnsLayout offre la possibilité de placer des éléments dans des colonnes spécifiques, donnant plus de contrôle sur l'agencement des éléments. Vous pouvez spécifier manuellement où un élément doit apparaître dans la mise en page, garantissant que les composants importants s'affichent comme prévu.

Placement de colonne de base

Par défaut, les éléments sont placés dans la prochaine colonne disponible, en remplissant de gauche à droite. Cependant, vous pouvez remplacer ce comportement et spécifier la colonne exacte dans laquelle un élément doit être placé. Pour placer un élément dans une colonne spécifique, utilisez la méthode setColumn(). Dans cet exemple, le bouton est placé dans la deuxième colonne de la mise en page, indépendamment de l'ordre dans lequel il a été ajouté par rapport aux autres composants :

Button button = new Button("Soumettre");
layout.addComponent(button);
// Placer l'élément dans la deuxième colonne
layout.setColumn(button, 2);

Ajustement du placement par point de rupture

Tout comme avec les spans de colonne, vous utilisez des points de rupture pour ajuster le placement des éléments en fonction de la taille de l'écran. Cela est utile pour réorganiser ou déplacer des éléments dans la mise en page à mesure que la vue change.

TextField email = new TextField("Email");
//...
List.of(
new ColumnsLayout.Breakpoint("default", 0 , 1),
new ColumnsLayout.Breakpoint("small", "20em", 1),
new ColumnsLayout.Breakpoint("medium", "40em", 2),
new ColumnsLayout.Breakpoint("large", "60em", 3)
)
//...
//le champ email apparaîtra dans la deuxième colonne lorsque le point de rupture moyen sera actif
columnsLayout.setColumn(email, "medium", 2);
//...

Dans la démonstration suivante, notez que lorsque le point de rupture "medium" est déclenché, le champ email s'étend sur les deux colonnes, et le champ confirmPassword est placé dans la première colonne, plutôt que son placement par défaut dans la deuxième colonne :

Afficher le code

Évitez les collisions

Lorsque plusieurs éléments sont placés dans une mise en page avec des spans et/ou des attributions de colonnes différents, assurez-vous que les spans et les placements combinés des éléments dans une rangée ne se chevauchent pas. La mise en page tente de gérer l'espacement automatiquement, mais un design minutieux des spans et des points de rupture empêche un affichage inattendu des éléments.

Alignements verticaux et horizontaux des éléments

Chaque élément dans le ColumnsLayout peut être aligné horizontalement et verticalement à l'intérieur de sa colonne, donnant le contrôle sur la façon dont le contenu est positionné à l'intérieur de la mise en page.

L'alignement horizontal d'un élément est contrôlé à l'aide de la méthode setHorizontalAlignment(). Cette propriété détermine comment un élément s'aligne à l'intérieur de sa colonne le long de l'axe horizontal.

L'alignement vertical spécifie comment un élément est positionné à l'intérieur de sa colonne le long de l'axe vertical. Ceci est utile lorsque les colonnes ont différentes hauteurs et que vous souhaitez contrôler comment les éléments sont distribués verticalement.

Les options d'Alignment disponibles comprennent :

  • START : Aligne l'élément à gauche de la colonne (par défaut).
  • CENTER : Centre l'élément horizontalement à l'intérieur de la colonne.
  • END : Aligne l'élément à droite de la colonne.
  • STRETCH : Étire le composant pour remplir la mise en page.
  • BASELINE : Aligne en fonction du texte ou du contenu à l'intérieur de la colonne, alignant les éléments sur la ligne de base du texte plutôt qu'avec d'autres options d'alignement.
  • AUTO : Alignement automatique.
Afficher le code

Dans la démo ci-dessus, le bouton Soumettre a été donné ColumnsLayout.Alignment.END pour s'assurer qu'il apparaît à la fin, ou dans ce cas à droite, de sa colonne.

Espacement des éléments

Contrôler l'espace entre les colonnes dans le ColumnsLayout entre les colonnes (espacement horizontal) et entre les rangées (espacement vertical) aide les développeurs à peaufiner la mise en page.

Pour définir l'espacement horizontal de la mise en page, utilisez la méthode setHorizontalSpacing() :

// Définir 20px d'espace entre les colonnes
layout.setHorizontalSpacing(20);

De même, utilisez la méthode setVerticalSpacing() pour configurer l'espace entre les rangées de la mise en page :

// Définir 15px d'espace entre les rangées
layout.setVerticalSpacing(15);
Unités CSS

Vous pouvez utiliser un entier pour définir la largeur minimale en pixels ou utiliser une String pour spécifier d'autres unités telles que vw, %, ou em.

Dispositions horizontales et verticales

Construire des mises en page réactives et attrayantes est possible en utilisant à la fois le composant FlexLayout et le composant ColumnsLayout, ainsi qu'une combinaison des deux. Ci-dessous se trouve un échantillon du formulaire créé dans l'article FlexLayout, mais utilisant un schéma ColumnLayout à la place :

Afficher le code

Stylisation

Loading...