


Ce didacticiel montre comment créer une application de visualisation de données à l'aide de l'API Google Charts et AngularJS, en se concentrant sur la liaison de données bidirectionnelle. Les pièces précédentes couvraient les contrôleurs et les directives; Cette pièce explore comment modifier dynamiquement les types de graphiques via un menu déroulant.
Caractéristiques de clé:
- Un menu déroulant permet aux utilisateurs de sélectionner les types de graphiques (Piechart, BarChart, ScatterChart, LineChart).
- La liaison des données bidirectionnelle d'AngularJS met automatiquement à jour la vue du graphique lorsque le modèle (type de graphique sélectionné) modifie.
-
ngOptions
etngModel
lier efficacement les options déroulantes et la valeur sélectionnée. -
ngChange
et$scope.$watch
Reriger dynamiquement le graphique en fonction de la sélection des utilisateurs.
Implémentation de la liste déroulante et de la liaison des données:
La liste déroulante est ajoutée à index.html
en tant qu'élément <select></select>
. Au lieu d'options de codage dur, nous définissons les types de graphiques dans controllers.js
en utilisant une approche angularjs:
$scope.chartTypes = [ {typeName: 'PieChart', typeValue: '1'}, {typeName: 'BarChart', typeValue: '2'}, {typeName: 'ColumnChart', typeValue: '3'}, {typeName: 'LineChart', typeValue: '4'} ]; $scope.chartType = $scope.chartTypes[0];
L'élément index.html
<select></select>
utilise ng-options
et ng-model
pour la liaison des données:
<select id="chartType" ng-model="chartType" ng-options="c.typeName for c in chartTypes"></select>
La directive ng-controller
dans index.html
doit être attachée à l'élément corporel pour une fonctionnalité appropriée.
Mises à jour du graphique dynamique:
La fonction selectType
dans controllers.js
met à jour le type de graphique en fonction de la sélection déroulante:
$scope.selectType = function(type) { $scope.chart.type = type.typeValue; };
La directive gChart
dans directives.js
utilise $scope.$watch
pour surveiller les changements dans $scope.chart
et redessiner le graphique en conséquence:
link: function($scope, elm, attrs) { $scope.$watch('chart', function() { var type = $scope.chart.type; var chart = ''; // Conditional chart creation based on type if (type == '1') { chart = new google.visualization.LineChart(elm[0]); } else if (type == '2') { chart = new google.visualization.BarChart(elm[0]); } else if (type == '3') { chart = new google.visualization.ColumnChart(elm[0]); } else if (type == '4') { chart = new google.visualization.PieChart(elm[0]); } chart.draw($scope.chart.data, $scope.chart.options); }, true); }
N'oubliez pas de démarrer le serveur de nœuds (node scripts/web-server.js
) et accédez à http://localhost:8000/app/index.html
pour voir l'application. Le code complet est disponible sur github (lien non fourni, car il n'était pas dans l'entrée).
Questions fréquemment posées (FAQ): (La section FAQ de l'entrée a été omise ici de garder la réponse concise. Les informations fournies abordent suffisamment la fonctionnalité de base du tutoriel.)
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!

Explication détaillée de la méthode de remplacement de la chaîne JavaScript et de la FAQ Cet article explorera deux façons de remplacer les caractères de chaîne dans JavaScript: le code JavaScript interne et le HTML interne pour les pages Web. Remplacer la chaîne dans le code JavaScript Le moyen le plus direct consiste à utiliser la méthode Remplace (): str = str.replace ("trouver", "remplacer"); Cette méthode remplace uniquement la première correspondance. Pour remplacer toutes les correspondances, utilisez une expression régulière et ajoutez le drapeau global G: str = str.replace (/ fi

Ce tutoriel vous montre comment intégrer une API de recherche Google personnalisée dans votre blog ou site Web, offrant une expérience de recherche plus raffinée que les fonctions de recherche de thème WordPress standard. C'est étonnamment facile! Vous pourrez restreindre les recherches à Y

Vous voici donc, prêt à tout savoir sur cette chose appelée Ajax. Mais qu'est-ce que c'est exactement? Le terme Ajax fait référence à un regroupement lâche de technologies utilisées pour créer un contenu Web interactif dynamique. Le terme Ajax, inventé à l'origine par Jesse J

Cette série d'articles a été réécrite à la mi-2017 avec des informations à jour et de nouveaux exemples. Dans cet exemple JSON, nous examinerons comment nous pouvons stocker des valeurs simples dans un fichier à l'aide du format JSON. En utilisant la notation de paire de valeurs clés, nous pouvons stocker n'importe quel type

Tirez parti de jQuery pour les dispositions de page Web sans effort: 8 plugins essentiels JQuery simplifie considérablement la mise en page de la page Web. Cet article met en évidence huit puissants plugins jQuery qui rationalisent le processus, particulièrement utile pour la création de sites Web manuels

Points de base Ceci dans JavaScript fait généralement référence à un objet qui "possède" la méthode, mais cela dépend de la façon dont la fonction est appelée. Lorsqu'il n'y a pas d'objet actuel, cela fait référence à l'objet global. Dans un navigateur Web, il est représenté par Window. Lorsque vous appelez une fonction, cela maintient l'objet global; mais lors de l'appel d'un constructeur d'objets ou de l'une de ses méthodes, cela fait référence à une instance de l'objet. Vous pouvez modifier le contexte de ceci en utilisant des méthodes telles que Call (), Appliquer () et Bind (). Ces méthodes appellent la fonction en utilisant la valeur et les paramètres donnés. JavaScript est un excellent langage de programmation. Il y a quelques années, cette phrase était

JQuery est un excellent cadre JavaScript. Cependant, comme pour n'importe quelle bibliothèque, il est parfois nécessaire de passer sous le capot pour découvrir ce qui se passe. C'est peut-être parce que vous tracez un bug ou que vous êtes simplement curieux de savoir comment jQuery réalise une interface utilisateur particulière

Ce message compile des feuilles de triche utiles, des guides de référence, des recettes rapides et des extraits de code pour le développement d'Android, BlackBerry et Iphone. Aucun développeur ne devrait être sans eux! Guide de référence sur les gestes touchés (PDF) Une ressource précieuse pour Desig


Outils d'IA chauds

Undresser.AI Undress
Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover
Outil d'IA en ligne pour supprimer les vêtements des photos.

Undress AI Tool
Images de déshabillage gratuites

Clothoff.io
Dissolvant de vêtements AI

AI Hentai Generator
Générez AI Hentai gratuitement.

Article chaud

Outils chauds

mPDF
mPDF est une bibliothèque PHP qui peut générer des fichiers PDF à partir de HTML encodé en UTF-8. L'auteur original, Ian Back, a écrit mPDF pour générer des fichiers PDF « à la volée » depuis son site Web et gérer différentes langues. Il est plus lent et produit des fichiers plus volumineux lors de l'utilisation de polices Unicode que les scripts originaux comme HTML2FPDF, mais prend en charge les styles CSS, etc. et présente de nombreuses améliorations. Prend en charge presque toutes les langues, y compris RTL (arabe et hébreu) et CJK (chinois, japonais et coréen). Prend en charge les éléments imbriqués au niveau du bloc (tels que P, DIV),

SublimeText3 version anglaise
Recommandé : version Win, prend en charge les invites de code !

Dreamweaver Mac
Outils de développement Web visuel

Télécharger la version Mac de l'éditeur Atom
L'éditeur open source le plus populaire

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP
