AngularJS - Contrôleurs
L'application AngularJS s'appuie principalement sur des contrôleurs pour contrôler le flux de données dans l'application. Un contrôleur est défini à l'aide de la directive ng-controller . Un contrôleur est un objet JavaScript qui contient des attributs / propriétés et des fonctions. Chaque contrôleur accepte $ scope comme paramètre, qui fait référence à l'application / module que le contrôleur doit gérer.
<div ng-app = "" ng-controller = "studentController">
...
</div>
Ici, nous déclarons un contrôleur nommé studentController , en utilisant la directive ng-controller. Nous le définissons comme suit -
<script>
function studentController($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
}
</script>
Le studentController est défini comme un objet JavaScript avec $ scope comme argument.
Le $ scope fait référence à l'application qui utilise l'objet studentController.
Le $ scope.student est une propriété de l'objet studentController.
Le firstName et le lastName sont deux propriétés de l'objet $ scope.student. Nous leur transmettons les valeurs par défaut.
La propriété fullName est la fonction de l'objet $ scope.student, qui renvoie le nom combiné.
Dans la fonction fullName, nous obtenons l'objet étudiant, puis renvoyons le nom combiné.
Pour mémoire, nous pouvons également définir l'objet contrôleur dans un fichier JS séparé et faire référence à ce fichier dans la page HTML.
Nous pouvons maintenant utiliser la propriété student de studentController en utilisant ng-model ou en utilisant les expressions suivantes -
Enter first name: <input type = "text" ng-model = "student.firstName"><br>
Enter last name: <input type = "text" ng-model = "student.lastName"><br>
<br>
You are entering: {{student.fullName()}}
Nous avons lié student.firstName et student.lastname à deux zones de saisie.
Nous avons lié student.fullName () à HTML.
Désormais, chaque fois que vous tapez quelque chose dans les champs de saisie du prénom et du nom, vous pouvez voir le nom complet se mettre à jour automatiquement.
Exemple
L'exemple suivant montre l'utilisation du contrôleur -
testAngularJS.htm
<html>
<head>
<title>Angular JS Controller</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "studentController">
Enter first name: <input type = "text" ng-model = "student.firstName"><br>
<br>
Enter last name: <input type = "text" ng-model = "student.lastName"><br>
<br>
You are entering: {{student.fullName()}}
</div>
<script>
var mainApp = angular.module("mainApp", []);
mainApp.controller('studentController', function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
</script>
</body>
</html>
Production
Ouvrez le fichier testAngularJS.htm dans un navigateur Web et voyez le résultat.