L'un des moyens les plus simples de séparer les données de vos documents HTML consiste à les stocker au format JSON. JSON est populaire et facile à utiliser, en particulier en JavaScript.
Dans React, il est logique de servir des données JSON via des tables à l'aide d'un composant. Ce composant pourra générer une table qui évolue avec les données JSON. La table résultante peut avoir autant de lignes que nécessaire puisque les données ne sont pas codées en dur.
Ce dont tu auras besoin
Vous aurez besoin de Node.js installé sur votre machine pour suivre ce tutoriel et une compréhension de base du fonctionnement de React.
Avant de créer le tableau, vous devrez créer un nouveau projet React si vous n'en avez pas.
Création des données JSON
La table utilisera des données stockées dans un fichier JSON. Tu pourrais récupérer ces données à partir d'un point de terminaison d'API dans une application réelle.
Dans le dossier src, créez un nouveau fichier appelé data.json et ajoutez ce qui suit :
[{
"identifiant
": 1,
"prénom": "Ethelred",
"nom de famille": "Tout doucement",
"e-mail": "[email protected]"
},{
"identifiant": 2,
"prénom": "Réta",
"nom de famille": "Laine",
"e-mail": "[email protected]"
},{
"identifiant": 3,
"prénom": "Arabe",
"nom de famille": "Pestor",
"e-mail": "[email protected]"
}]
Il s'agit d'un simple fichier JSON contenant trois objets.
Les clés d'objet - l'identifiant, le prénom, le nom et l'e-mail - sont les en-têtes, tandis que leurs propriétés correspondantes constituent le corps du tableau.
Création du composant de table
Créez un nouveau fichier appelé Table.js dans le dossier src et ajoutez le code suivant.
exporterdéfautfonctionTable({theadData, tbodyData}) {
revenir (
<table>
<tête>
<tr>
// ligne d'en-tête
</tr>
</thead>
<le corps>
// données du corps
</tbody>
</table>
);
}
Ce composant prend theadData et tBodyData comme accessoires. theadData contient les données que vous afficherez dans la ligne d'en-tête. L'application se procurera ces données à partir du fichier JSON et les transmettra au composant Table.
Créer une fonction dans App.js appelé getHeadings() et ajoutez ce qui suit.
constante getHeadings = () => {
revenirObjet.keys (données[0]);
}
Étant donné que les clés de chaque objet du fichier JSON sont similaires, vous pouvez simplement utiliser les clés du premier objet.
N'oubliez pas d'importer data.json dans App.js.
importer Les données de "./data.json"
Lorsque vous affichez le composant Table, transmettez l'en-tête et les données JSON en tant qu'accessoires.
<Tableau theadData={getHeadings()} tbodyData={data}/>
Création de la ligne d'en-tête
Dans cette étape, vous allez créer un composant pour afficher un élément dans la ligne d'en-tête. Ce composant itérera sur les en-têtes à l'aide de la méthode map().
Dans Table.js, ajoutez le code pour parcourir les en-têtes à l'intérieur de la balise thead.
<tr>
{theadData.map (titre => {
revenir <ème clé={titre}>{titre}</th>
})}
</tr>
Ensuite, vous remplirez le corps du tableau.
Création des rangées de corps
Le corps du tableau restitue les données de la ligne. Étant donné que Table.js reçoit les données sous forme de tableau d'objets, vous devrez d'abord parcourir celui-ci pour obtenir chaque objet représentant une ligne.
Ainsi, dans Table.js, parcourez le prop tBodyData comme ceci :
<le corps>
{tbodyData.map((ligne, index) => {
revenir <tr clé={index}>
// données de ligne
</tr>;
})}
</tbody>
Chaque objet de ligne sera similaire à l'exemple d'objet ci-dessous.
constante ligne = {
"identifiant": 1,
"prénom": "Ethelred",
"nom de famille": "Tout doucement",
"e-mail": "[email protected]"
}
Pour afficher chacun de ces éléments, vous devrez itérer sur les clés de l'objet. Dans chaque itération, vous récupérerez la propriété qui correspond à cette clé dans l'objet de ligne. Étant donné que ces clés sont les mêmes que les en-têtes, utilisez les valeurs de la propriété theadData.
Modifiez la balise tr pour afficher les données de ligne comme indiqué ci-dessous.
<tr clé={index}>
// theadData contient les clés
{theadData.map((clé, index) => {
revenir <td clé={ligne[clé]}>{ligne[clé]}</td>
})}
</tr>;
En rassemblant tout, le composant Table devrait ressembler à ceci :
exporterdéfautfonctionTable({theadData, tbodyData}) {
revenir (
<table>
<tête>
<tr>
{theadData.map (titre => {
revenir <ème clé={titre}>{titre}</th>
})}
</tr>
</thead>
<le corps>
{tbodyData.map((ligne, index) => {
revenir <tr clé={index}>
{theadData.map((clé, index) => {
revenir <td clé={ligne[clé]}>{ligne[clé]}</td>
})}
</tr>;
})}
</tbody>
</table>
);
}
Dans le
élément, le composant itère sur le tableau de données et renvoie la ligne du tableau pour chaque objet.Utilisation du composant tableau
Importez la table dans App.js et affichez-la comme indiqué ci-dessous :
importer Table de './Table';
importer Les données de "./data.json"
fonctionApplication() {
constante getHeadings = () => {
revenirObjet.keys (données[0]);
}
revenir (
<div nom_classe="récipient">
<Tableau theadData={getHeadings()} tbodyData={data}/>
</div>
);
}
exporterdéfaut application ;
Le composant table prend theadData et tbodyData comme accessoires. theadData contient les en-têtes générés à partir des clés du premier élément des données JSON, et tbodyData contient l'intégralité du fichier JSON.
Styler avec les modules CSS
Vous avez généré un composant de table React à partir d'un fichier JSON dans ce didacticiel. Vous avez également appris comment manipuler les données JSON pour répondre à vos besoins. Vous pouvez améliorer l'apparence de votre tableau en y ajoutant du CSS. Pour créer des styles CSS de portée locale, envisagez d'utiliser des modules CSS. Il est simple à utiliser et facile à utiliser si vous utilisez une application create-react-app.