📈TD 1 - Premiers graphiques
Retour sur les maquettes
N'hésitez pas à ajouter de la couleur, faire un travail sur le choix des polices, travail sur les typographies, ...
Des mises en avant de chiffres, de phrases, ... (animées ou non), peuvent être pertinentes pour casser une routine de lecture sur les pages.
Des photos et illustrations peuvent être utilisées
Une icônographie peut être utilisée
Questions/réponses
Pas de responsive imposé
Librairies CSS autorisées
Icône, images existantes autorisées
Création de graphiques en JavaScript
Pour générer des graphiques sur le web il existe plusieurs solutions
Méthodes statiques
L'image et le graphique sont construits avec un logiciel de création graphique classique, ou excel, ou équivalent. L'image est enregistrée et on la dépose sur le serveur web pour l'afficher comme une image classique.
Méthodes "dynamique"
On peut générer en back en créant une image, à partir de données en PHP (avec la librairie GD ou d'autres (http://www.pchart.net/ par exemple), et l'afficher comme une image. Cette solution est intéressante, mais ne permet pas forcément une grande interactivité avec le graphique produit
Le générer avec un langage front, comme JavaScript. Dans ce cas il existe de nombreuses librairies (une liste non exhaustive ici : https://geekflare.com/fr/charting-libraries/). Cette solution permet une grande interactivité avec les données et le résultat produit.
d3js (https://observablehq.com/@d3/gallery) est la librairie la plus complète, mais aussi un peu plus difficile à mettre en place.
Librairies JS
Pour ce premier exemple on va utiliser Chart.js (mais toutes les autres fonctionnent sur une logique similaire).
ChartJs, va générer du Canvas qui est intégré directement dans votre page HTML à partir d'une source de données JavaScript.
Mise en place
Partie HTML
Intégration du graphique dans votre page HTML
Il faut définir un objet "canvas" avec un id, dans lequel le graphique sera inséré. Vous pouvez ajouter autant de zone de graphique que vous le souhaitez.
Il faut ensuite ajouter la dépendance à ChartJs
Soit en CDN (comme ci-dessus) ou en intégrant les fichiers que vous auriez téléchargé.
Partie JavaScript
Soit directement dans le fichier HTML, soit en incluant un fichier js.
Le code ci-dessus permet de construire un objet Chart, avec deux paramètres :
L'id (lien avec le canva) où sera mis en place le graphique
Un objet JSON qui contient la construction du graphique.
Cette seconde partie de code va permettre de définir les éléments du graphique.
Le type (line, pie, plot, ...)
Les "data" (la forme de cette partie peut varier selon le type de graphique)
Les "data" sont souvent composées d'un nom (label), de données (data), et souvent de paramètres de couleurs ou d'option. Consulter la documentation pour chaque type de graphique.
Exercice
Mettre en place votre premier graphique avec ChartJS (ou une librairie de votre choix)
Gestion des données
Comme vous le constatez les données sont inscrites directement dans la configuration. Ce qui peut être bien, mais n'est pas forcément optimal si les données doivent changer régulièrement.
Elles peuvent donc provenir d'un fichier JSON qui serait récupéré depuis une API par exemple, ou d'un appel API directement, ...
Ci-dessous un exemple se basant sur un fichier JSON.
Import d'un fichier JSON
Soit si c'est un fichier JavaScript importé
Modification
Le code du graphique doit donc manipuler les données du fichier Json
Exemple de fichier JSON
Exemple d'utilisation dans le javascript
Ajouter des données
Il est possible d'ajouter ou de retirer des données en lien avec un graphique existant.
Exemple de code javascript, à associer sur un bouton avec un id "bouton", et un chart nommé charteGenreMMI2. Les données sont fixées par le code ici, elles peuvent venir de sources, de formulaires, ...
Documentation associée :
Dernière mise à jour