Maison >développement back-end >tutoriel php >Explication détaillée de la création de graphiques dynamiques en PHP basés sur canvasJS
<img src="https://img.php.cn/upload/article/202008/04/2020080415471934199.jpg" alt="Explication détaillée de la création de graphiques dynamiques en PHP basés sur canvasJS" >
CanvasJS
est une bibliothèque JavaScript permettant de créer facilement d'autres types de graphiques pour les pages Web. Par exemple, un graphique à barres, un graphique à secteurs, un graphique à colonnes, un graphique en aires, un graphique en courbes, etc.
Prenons un exemple où nous devons créer un graphique où nous pouvons montrer les produits vendus et achetés chaque mois. Nous considérerons deux tableaux, nous pouvons également les considérer à partir de la base de données. Une fois que nous avons récupéré les données de la base de données et les avons stockées dans un tableau, elles peuvent être facilement dessinées avec des graphiques dynamiques à l'aide de canvasJS.
Créez un fichier et enregistrez-le dans le dossier du projet. Le nom du fichier chart_sample.php
contient des données sous forme de tableaux, où le premier tableau représente les produits achetés et le deuxième tableau représente la liste des produits sols. Maintenant, utilisez canvasJS pour dessiner les graphiques.
Par exemple :
<?php // First array for purchased product $purchased= array(10, 15, 19, 0, 5, 7, 0, 0, 12, 13, 10, 1); // Second array for sold product $sold= array(7, 12, 14, 0, 3, 7, 0, 0, 10, 7, 5, 0); // Data to draw graph for purchased products $dataPoints = array( array("label"=> "Jan", "y"=> $purchased[0]), array("label"=> "Feb", "y"=> $purchased[1]), array("label"=> "March", "y"=> $purchased[2]), array("label"=> "April", "y"=> $purchased[3]), array("label"=> "May", "y"=> $purchased[4]), array("label"=> "Jun", "y"=> $purchased[5]), array("label"=> "July", "y"=> $purchased[6]), array("label"=> "Aug", "y"=> $purchased[7]), array("label"=> "Sep", "y"=> $purchased[8]), array("label"=> "Oct", "y"=> $purchased[9]), array("label"=> "Nov", "y"=> $purchased[10]), array("label"=> "Dec", "y"=> $purchased[11]) ); // Data to draw graph for sold products $dataPoints2 = array( array("label"=> "Jan", "y"=> $sold[0]), array("label"=> "Feb", "y"=> $sold[1]), array("label"=> "March", "y"=> $sold[2]), array("label"=> "April", "y"=> $sold[3]), array("label"=> "May", "y"=> $sold[4]), array("label"=> "Jun", "y"=> $sold[5]), array("label"=> "July", "y"=> $sold[6]), array("label"=> "Aug", "y"=> $sold[7]), array("label"=> "Sep", "y"=> $sold[8]), array("label"=> "Oct", "y"=> $sold[9]), array("label"=> "Nov", "y"=> $sold[10]), array("label"=> "Dec", "y"=> $sold[11]) ); ?>
<!DOCTYPE HTML> <html> <head> <script src="https://canvasjs.com/assets/script/canvasjs.min.js"> </script> <script> window.onload = function () { var chart = new CanvasJS.Chart("chartContainer", { animationEnabled: true, title:{ text: "Monthly Purchased and Sold Product" }, axisY: { title: "Purchased", titleFontColor: "#4F81BC", lineColor: "#4F81BC", labelFontColor: "#4F81BC", tickColor: "#4F81BC" }, axisY2: { title: "Sold", titleFontColor: "#C0504E", lineColor: "#C0504E", labelFontColor: "#C0504E", tickColor: "#C0504E" }, toolTip: { shared: true }, legend: { cursor:"pointer", itemclick: toggleDataSeries }, data: [{ type: "column", name: "Purchased", legendText: "Purchased", showInLegend: true, dataPoints:<?php echo json_encode($dataPoints, JSON_NUMERIC_CHECK); ?> }, { type: "column", name: "Sold", legendText: "Sold", axisYType: "secondary", showInLegend: true, dataPoints:<?php echo json_encode($dataPoints2, JSON_NUMERIC_CHECK); ?> }] }); chart.render(); function toggleDataSeries(e) { if (typeof(e.dataSeries.visible) === "undefined" || e.dataSeries.visible) { e.dataSeries.visible = false; } else { e.dataSeries.visible = true; } chart.render(); } } </script> </head> <body> <p id="chartContainer" style="height: 300px; width: 100%;"></p> </body> </html>
Recommandations d'apprentissage associées : Programmation PHP de l'entrée à la maîtrise
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!