Sorting
Le tri permet aux utilisateurs d'organiser les données dans des colonnes par ordre, rendant l'information plus facile à lire et à analyser. Cela est utile lorsque les utilisateurs doivent trouver rapidement les valeurs les plus élevées ou les plus basses dans une colonne particulière.
Pour des informations sur la façon d'utiliser le modèle Repository pour gérer et interroger des collections, consultez les articles du Repository.
Afficher le code
- Java
Par défaut, une colonne n'est pas triable, sauf si elle est explicitement activée. Pour permettre le tri sur une colonne spécifique, utilisez la méthode setSortable(true) :
table.getColumn("Age").setSortable(true);
Tri multi-colonnes
25.00Avant webforj 25.00, les tableaux prenaient en charge le tri multi-colonnes par défaut. À partir de la version 25.00, ce comportement a changé : les développeurs doivent maintenant activer explicitement le tri multi-colonnes.
Si le tri multi est nécessaire, setMultiSorting(true) doit être appliqué au tableau. Cela permet aux utilisateurs de trier plusieurs colonnes dans une séquence :
table.setMultiSorting(true);
Avec le tri multi activé, cliquer sur plusieurs en-têtes de colonnes les triera séquentiellement. La priorité de tri est visuellement indiquée dans l'interface utilisateur du tableau.
Afficher le code
- Java
Vous pouvez également définir la priorité de tri de manière programmatique pour le tri côté serveur. Utilisez setSortOrder() sur les colonnes que vous souhaitez trier, dans l'ordre de priorité :
// Ordre de tri côté serveur
nameColumn.setSortOrder(1);
ageColumn.setSortOrder(2);
À moins que setSortOrder() ne soit utilisé, le tableau par défaut trie selon l'ordre dans lequel les colonnes sont déclarées.
Afficher le code
- Java
Direction de tri
Il y a trois paramètres disponibles pour la direction dans laquelle une colonne peut être triée :
SortDirection.ASC: Trie la colonne par ordre croissant.SortDirection.DESC: Trie la colonne par ordre décroissant.SortDirection.NONE: Aucun tri appliqué à la colonne.
Lorsque le tri est activé pour une colonne, un ensemble d'indicateurs fléchés verticaux apparaît en haut de la colonne concernée. Ces flèches permettent à l'utilisateur de basculer entre les différentes directions de tri.
Lorsque l'ordre croissant est sélectionné, un ^ sera affiché, tandis que l'ordre décroissant affichera un v.
Tri côté client vs côté serveur
Le tri des données peut être catégorisé en deux approches principales : Tri côté client et Tri côté serveur.
Tri côté client
Le tri côté client consiste à organiser et afficher les données directement dans l'interface utilisateur de l'application cliente. C'est le tri avec lequel les utilisateurs interagissent lorsqu'ils cliquent sur les en-têtes de colonnes, influençant la représentation visuelle des données à l'écran.
Le développeur n'a pas de contrôle direct sur le tri côté client, mais il est plutôt déterminé par le type de colonne fourni en Java. Les types suivants sont actuellement pris en charge :
- TEXT
- NUMBER
- BOOLEAN
- DATE
- DATETIME
- TIME
Le tri côté client ne fonctionne pas lorsque seule une partie des données est disponible dans le client.
Tri côté serveur
Contrairement au tri côté client, le tri côté serveur consiste à organiser et structurer les données sur le serveur avant de les transmettre au client. Cette approche est particulièrement bénéfique lorsqu'il s'agit de grandes quantités de données qui pourraient être impraticables à transférer complètement au client.
Les développeurs ont plus de contrôle sur la logique du tri côté serveur. Cela permet la mise en œuvre d'algorithmes de tri complexes et d'optimisations, rendant cette méthode adaptée aux scénarios avec des données volumineuses. Cela garantit que le client reçoit des données pré-triées, minimisant la nécessité d'un traitement extensif côté client.
Le tri côté serveur est une stratégie orientée performance pour gérer des ensembles de données qui dépassent les capacités d'un traitement efficace côté client, et est la méthode par défaut utilisée par le Table.
Nom de propriété de colonne
Par défaut, le Table utilise l'ID d'une colonne comme nom de propriété lors de la construction des critères de tri pour un référentiel en backend. Lorsque l'ID d'affichage d'une colonne ne correspond pas à la propriété de données sous-jacente, ou lorsque la colonne affiche une valeur calculée, utilisez setPropertyName() pour indiquer explicitement au Table quelle propriété trier.
// L'ID de la colonne est "Full Name", mais la propriété en backend est "fullName"
table.addColumn("Full Name", Person::getFullName)
.setSortable(true)
.setPropertyName("fullName");
Le nom de propriété est transmis à l'OrderCriteria lorsqu'un événement de tri se déclenche, permettant aux référentiels en backend tels que Spring Data JPA ou les adaptateurs REST de construire la clause ORDER BY correcte.
Sans setPropertyName(), le Table revient à l'ID de la colonne. Si cela ne correspond pas à une propriété valide en backend, le tri échouera silencieusement ou renverra des données mal ordonnées.
Les chemins de propriétés imbriquées sont également pris en charge en utilisant la notation par points :
table.addColumn("City", Person::getCity)
.setSortable(true)
.setPropertyName("address.city");
Comparateurs
Le composant Column permet aux développeurs d'utiliser des Comparators Java pour un tri dynamique et personnalisé. Un Comparator est un mécanisme utilisé pour ordonner deux objets de la même classe, même si cette classe est définie par l'utilisateur. Cette fonctionnalité offre aux développeurs la flexibilité de personnaliser la façon dont les données sont triées, fournissant un contrôle accru sur le comportement de tri par défaut basé sur un ordre naturel.
Pour tirer parti du tri avec Comparator dans un Column, vous pouvez utiliser la méthode setComparator(). Cette méthode vous permet de définir une fonction Comparator personnalisée qui dicte la logique de tri.
Afficher le code
- Java
Dans l'exemple ci-dessus, une fonction de comparateur personnalisée est spécifiée, qui prend deux éléments (a et b), et définit l'ordre de tri basé sur les valeurs entières analysées de l'attribut Number.
Utiliser des Comparateurs pour le tri des colonnes est particulièrement utile lors de la gestion de valeurs non numériques. Ils sont également utiles pour la mise en œuvre d'algorithmes de tri complexes.
Par défaut, le Table utilise le tri côté serveur et trie les valeurs non primitives en utilisant la méthode toString() de l'objet, les convertissant en leurs valeurs string, puis les triant.