AngularJS - Modules
AngularJS prend en charge l'approche modulaire. Les modules sont utilisés pour séparer la logique telle que les services, les contrôleurs, les applications, etc. du code et maintenir le code propre. Nous définissons les modules dans des fichiers js séparés et les nommons selon le fichier module.js. Dans l'exemple suivant, nous allons créer deux modules -
Application Module - utilisé pour initialiser une application avec des contrôleurs.
Controller Module - utilisé pour définir le contrôleur.
Module d'application
Voici un fichier nommé mainApp.js qui contient le code suivant -
var mainApp = angular.module("mainApp", []);
Ici, nous déclarons une candidature mainAppmodule en utilisant la fonction angular.module et lui passer un tableau vide. Ce tableau contient généralement des modules dépendants.
Module contrôleur
studentController.js
mainApp.controller("studentController", function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65},
{name:'English',marks:75},
{name:'Hindi',marks:67}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
Ici, nous déclarons un contrôleur studentController module utilisant la fonction mainApp.controller.
Utiliser des modules
<div ng-app = "mainApp" ng-controller = "studentController">
...
<script src = "mainApp.js"></script>
<script src = "studentController.js"></script>
</div>
Ici, nous utilisons le module d'application utilisant la directive ng-app et le contrôleur utilisant la directive ngcontroller. Nous importons les mainApp.js et studentController.js dans la page HTML principale.
Exemple
L'exemple suivant montre l'utilisation de tous les modules mentionnés ci-dessus.
testAngularJS.htm
<html>
<head>
<title>Angular JS Modules</title>
<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
<script src = "/angularjs/src/module/mainApp.js"></script>
<script src = "/angularjs/src/module/studentController.js"></script>
<style>
table, th , td {
border: 1px solid grey;
border-collapse: collapse;
padding: 5px;
}
table tr:nth-child(odd) {
background-color: #f2f2f2;
}
table tr:nth-child(even) {
background-color: #ffffff;
}
</style>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app = "mainApp" ng-controller = "studentController">
<table border = "0">
<tr>
<td>Enter first name:</td>
<td><input type = "text" ng-model = "student.firstName"></td>
</tr>
<tr>
<td>Enter last name: </td>
<td><input type = "text" ng-model = "student.lastName"></td>
</tr>
<tr>
<td>Name: </td>
<td>{{student.fullName()}}</td>
</tr>
<tr>
<td>Subject:</td>
<td>
<table>
<tr>
<th>Name</th>
<th>Marks</th>
</tr>
<tr ng-repeat = "subject in student.subjects">
<td>{{ subject.name }}</td>
<td>{{ subject.marks }}</td>
</tr>
</table>
</td>
</tr>
</table>
</div>
</body>
</html>
mainApp.js
var mainApp = angular.module("mainApp", []);
studentController.js
mainApp.controller("studentController", function($scope) {
$scope.student = {
firstName: "Mahesh",
lastName: "Parashar",
fees:500,
subjects:[
{name:'Physics',marks:70},
{name:'Chemistry',marks:80},
{name:'Math',marks:65},
{name:'English',marks:75},
{name:'Hindi',marks:67}
],
fullName: function() {
var studentObject;
studentObject = $scope.student;
return studentObject.firstName + " " + studentObject.lastName;
}
};
});
Production
Ouvrez le fichier textAngularJS.htm dans un navigateur Web. Voyez le résultat.