AngularJS - Guide rapide

Qu'est-ce que AngularJS?

AngularJS est un framework d'application Web open source. Il a été développé à l'origine en 2009 par Misko Hevery et Adam Abrons. Il est maintenant maintenu par Google. Sa dernière version est la 1.4.3.

La définition d'AngularJS telle que présentée par sa documentation officielle est la suivante -

AngularJS est un cadre structurel pour les applications Web dynamiques. Il vous permet d'utiliser HTML comme langage de modèle et vous permet d'étendre la syntaxe de HTML pour exprimer les composants de votre application de manière claire et succincte. La liaison de données et l'injection de dépendances d'Angular éliminent une grande partie du code que vous devez actuellement écrire. Et tout se passe dans le navigateur, ce qui en fait le partenaire idéal de toute technologie de serveur.

traits

  • AngularJS est un puissant cadre de développement basé sur JavaScript pour créer une application Internet RICHE (RIA).

  • AngularJS fournit aux développeurs des options pour écrire une application côté client (à l'aide de JavaScript) d'une manière propre MVC (Model View Controller).

  • L'application écrite en AngularJS est compatible avec tous les navigateurs. AngularJS gère automatiquement le code JavaScript adapté à chaque navigateur.

  • AngularJS est open source, entièrement gratuit et utilisé par des milliers de développeurs à travers le monde. Il est sous licence Apache License version 2.0.

Dans l'ensemble, AngularJS est un framework permettant de créer des applications Web à grande échelle et hautes performances tout en les gardant faciles à entretenir.

CARACTERISTIQUES de base

Voici les principales fonctionnalités de base d'AngularJS -

  • Data-binding - C'est la synchronisation automatique des données entre les composants du modèle et de la vue.

  • Scope- Ce sont des objets qui font référence au modèle. Ils agissent comme un lien entre le contrôleur et la vue.

  • Controller - Ce sont des fonctions JavaScript liées à une portée particulière.

  • Services- AngularJS est livré avec plusieurs services intégrés, par exemple $ https: pour créer un XMLHttpRequests. Ce sont des objets singleton qui ne sont instanciés qu'une seule fois dans l'application.

  • Filters - Ceux-ci sélectionnent un sous-ensemble d'éléments d'un tableau et retournent un nouveau tableau.

  • Directives- Les directives sont des marqueurs sur les éléments DOM (tels que les éléments, les attributs, les css, etc.). Ceux-ci peuvent être utilisés pour créer des balises HTML personnalisées qui servent de nouveaux widgets personnalisés. AngularJS a des directives intégrées (ngBind, ngModel ...)

  • Templates- Voici la vue rendue avec les informations du contrôleur et du modèle. Il peut s'agir d'un seul fichier (comme index.html) ou de plusieurs vues sur une page en utilisant des "partiels".

  • Routing - C'est le concept de changement de vue.

  • Model View Whatever- MVC est un modèle de conception permettant de diviser une application en différentes parties (appelées modèle, vue et contrôleur), chacune avec des responsabilités distinctes. AngularJS n'implémente pas MVC au sens traditionnel du terme, mais plutôt quelque chose de plus proche de MVVM (Model-View-ViewModel). L'équipe Angular JS l'appelle avec humour Model View Whatever.

  • Deep Linking- Le lien profond vous permet d'encoder l'état de l'application dans l'URL afin qu'elle puisse être mise en signet. L'application peut ensuite être restaurée à partir de l'URL dans le même état.

  • Dependency Injection - AngularJS dispose d'un sous-système d'injection de dépendances intégré qui aide le développeur en facilitant le développement, la compréhension et le test de l'application.

Concepts

Le diagramme suivant décrit certaines parties importantes d'AngularJS dont nous discuterons en détail dans les chapitres suivants.

Avantages d'AngularJS

  • AngularJS offre la possibilité de créer une application à page unique d'une manière très propre et maintenable.

  • AngularJS fournit une capacité de liaison de données à HTML offrant ainsi à l'utilisateur une expérience riche et réactive

  • Le code AngularJS est testable unitaire.

  • AngularJS utilise l'injection de dépendances et utilise la séparation des préoccupations.

  • AngularJS fournit des composants réutilisables.

  • Avec AngularJS, les développeurs écrivent moins de code et obtiennent plus de fonctionnalités.

  • Dans AngularJS, les vues sont de pures pages HTML et les contrôleurs écrits en JavaScript effectuent le traitement métier.

En plus de tout, les applications AngularJS peuvent fonctionner sur tous les principaux navigateurs et téléphones intelligents, y compris les téléphones / tablettes Android et iOS.

Inconvénients d'AngularJS

Bien qu'AngularJS soit livré avec beaucoup de points positifs, mais en même temps, nous devrions considérer les points suivants -

  • Not Secure- Étant uniquement un framework JavaScript, les applications écrites en AngularJS ne sont pas sûres. L'authentification et l'autorisation côté serveur sont indispensables pour garantir la sécurité d'une application.

  • Not degradable - Si l'utilisateur de votre application désactive JavaScript, l'utilisateur ne verra que la page de base et rien de plus.

Les composants AngularJS

Le framework AngularJS peut être divisé en trois parties principales:

  • ng-app - Cette directive définit et lie une application AngularJS à HTML.

  • ng-model - Cette directive lie les valeurs des données d'application AngularJS aux contrôles d'entrée HTML.

  • ng-bind - Cette directive lie les données de l'application AngularJS aux balises HTML.

Dans ce chapitre, nous discuterons de la façon de configurer la bibliothèque AngularJS à utiliser dans le développement d'applications Web. Nous étudierons également brièvement la structure du répertoire et son contenu.

Lorsque vous ouvrez le lien https://angularjs.org/, vous verrez qu'il existe deux options pour télécharger la bibliothèque AngularJS -

  • View on GitHub - Cliquez sur ce bouton pour accéder à GitHub et obtenir tous les derniers scripts.

  • Download AngularJS 1 - Ou cliquez sur ce bouton, un écran comme ci-dessous apparaîtra -

  • Cet écran propose différentes options d'utilisation d'Angular JS comme suit -

    • Downloading and hosting files locally

      • Il existe deux options différentes legacy et latest. Les noms eux-mêmes sont auto-descriptifs.legacy a une version inférieure à 1.2.x et latest a la version 1.5.x.

      • Nous pouvons également aller avec la version minifiée, non compressée ou zippée.

    • CDN access- Vous avez également accès à un CDN. Le CDN vous donnera accès dans le monde entier à des centres de données régionaux qui, dans ce cas, hébergent Google. Cela signifie que l'utilisation de CDN déplace la responsabilité de l'hébergement des fichiers de vos propres serveurs vers une série de serveurs externes. Cela offre également un avantage: si le visiteur de votre page Web a déjà téléchargé une copie d'AngularJS à partir du même CDN, il n'aura pas à être retéléchargé.

  • Try the new angularJS 2 - Cliquez sur ce bouton pour télécharger la version bêta d'Angular JS 2. Cette version est très rapide, prise en charge mobile et flexible par rapport à l'ancienne et la dernière version d'AngularJS 1

Nous utilisons les versions CDN de la bibliothèque tout au long de ce didacticiel.

Exemple

Maintenant, écrivons un exemple simple en utilisant la bibliothèque AngularJS. Créons un fichier HTML myfirstexample.html comme ci-dessous -

<!doctype html>
<html>
   
   <head>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.5.2/angular.min.js"></script>
   </head>
   
   <body ng-app = "myapp">
      
      <div ng-controller = "HelloController" >
         <h2>Welcome {{helloTo.title}} to the world of Tutorialspoint!</h2>
      </div>
      
      <script>
         angular.module("myapp", [])
         
         .controller("HelloController", function($scope) {
            $scope.helloTo = {};
            $scope.helloTo.title = "AngularJS";
         });
      </script>
      
   </body>
</html>

Les sections suivantes décrivent le code ci-dessus en détail -

Inclure AngularJS

Nous avons inclus le fichier JavaScript AngularJS dans la page HTML afin que nous puissions utiliser AngularJS -

<head>
   <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
</head>

Si vous souhaitez mettre à jour vers la dernière version d'Angular JS, utilisez la source de script suivante ou vérifiez la dernière version d'AngularJS sur leur site officiel.

<head>
   <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.5.2/angular.min.js"></script>
</head>

Pointez sur l'application AngularJS

Ensuite, nous disons quelle partie du HTML contient l'application AngularJS. Cela se fait en ajoutant l' attribut ng-app à l'élément HTML racine de l'application AngularJS. Vous pouvez l'ajouter à l' élément html ou à l' élément body comme indiqué ci-dessous -

<body ng-app = "myapp">
</body>

Vue

La vue est cette partie -

<div ng-controller = "HelloController" >
   <h2>Welcome {{helloTo.title}} to the world of Tutorialspoint!</h2>
</div>

ng-controller indique à AngularJS quel contrôleur utiliser avec cette vue. helloTo.title indique à AngularJS d'écrire la valeur "modèle" nommée helloTo.title dans le code HTML à cet emplacement.

Manette

La partie contrôleur est -

<script>
   angular.module("myapp", [])
   
   .controller("HelloController", function($scope) {
      $scope.helloTo = {};
      $scope.helloTo.title = "AngularJS";
   });
</script>

Ce code enregistre une fonction de contrôleur nommée HelloController dans le module angulaire nommé myapp . Nous étudierons plus en détail les modules et les contrôleurs dans leurs chapitres respectifs. La fonction régulateur est enregistrée en angulaire via l'appel de fonction module angulaire (...). Régulateur (...).

Le paramètre $ scope passé à la fonction de contrôleur est le modèle . La fonction de contrôleur ajoute un objet helloTo JavaScript, et dans cet objet, elle ajoute un champ de titre .

Exécution

Enregistrez le code ci-dessus sous myfirstexample.html et ouvrez-le dans n'importe quel navigateur. Vous verrez une sortie comme ci-dessous -

Welcome AngularJS to the world of Tutorialspoint!

Lorsque la page est chargée dans le navigateur, les choses suivantes se produisent -

  • Le document HTML est chargé dans le navigateur et évalué par le navigateur. Le fichier JavaScript AngularJS est chargé, l' objet global angulaire est créé. Ensuite, JavaScript qui enregistre les fonctions du contrôleur est exécuté.

  • Ensuite, AngularJS parcourt le HTML pour rechercher des applications et des vues AngularJS. Une fois la vue localisée, elle connecte cette vue à la fonction de contrôleur correspondante.

  • Ensuite, AngularJS exécute les fonctions du contrôleur. Il rend ensuite les vues avec les données du modèle rempli par le contrôleur. La page est maintenant prête.

Model View Controller ou MVC comme on l'appelle communément, est un modèle de conception de logiciel pour le développement d'applications Web. Un modèle Model View Controller est composé des trois parties suivantes:

  • Model - C'est le niveau le plus bas du modèle responsable de la conservation des données.

  • View - Il est responsable de l'affichage de tout ou partie des données à l'utilisateur.

  • Controller - C'est un code logiciel qui contrôle les interactions entre le modèle et la vue.

MVC est populaire car il isole la logique d'application de la couche d'interface utilisateur et prend en charge la séparation des préoccupations. Le contrôleur reçoit toutes les demandes de l'application, puis travaille avec le modèle pour préparer toutes les données nécessaires à la vue. La vue utilise ensuite les données préparées par le contrôleur pour générer une réponse présentable finale. L'abstraction MVC peut être représentée graphiquement comme suit.

Le modèle

Le modèle est responsable de la gestion des données d'application. Il répond à la demande de view et aux instructions du contrôleur de se mettre à jour.

La vue

Une présentation des données dans un format particulier, déclenchée par la décision du responsable du traitement de présenter les données. Ce sont des systèmes de modèles basés sur des scripts tels que JSP, ASP, PHP et très faciles à intégrer avec la technologie AJAX.

Le controlle

Le contrôleur répond aux entrées de l'utilisateur et effectue des interactions sur les objets du modèle de données. Le contrôleur reçoit une entrée, la valide, puis effectue des opérations commerciales qui modifient l'état du modèle de données.

AngularJS est un framework basé sur MVC. Dans les prochains chapitres, nous verrons comment AngularJS utilise la méthodologie MVC.

Avant de commencer à créer une application HelloWorld réelle à l'aide d'AngularJS, voyons quelles sont les parties réelles d'une application AngularJS. Une application AngularJS se compose de trois parties importantes:

  • ng-app - Cette directive définit et lie une application AngularJS à HTML.

  • ng-model - Cette directive lie les valeurs des données d'application AngularJS aux contrôles d'entrée HTML.

  • ng-bind - Cette directive lie les données de l'application AngularJS aux balises HTML.

Étapes pour créer une application AngularJS

Étape 1: Charger le framework

Étant un framework JavaScript pur, il peut être ajouté en utilisant la balise <Script>.

<script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
</script>

Étape 2: définir l'application AngularJS à l'aide de la directive ng-app

<div ng-app = "">
   ...
</div>

Étape 3: définir un nom de modèle à l'aide de la directive ng-model

<p>Enter your Name: <input type = "text" ng-model = "name"></p>

Étape 4: Liez la valeur du modèle ci-dessus défini à l'aide de la directive ng-bind.

<p>Hello <span ng-bind = "name"></span>!</p>

Étapes pour exécuter l'application AngularJS

Utilisez les trois étapes mentionnées ci-dessus dans une page HTML.

testAngularJS.htm

<html>
   <head>
      <title>AngularJS First Application</title>
   </head>
   
   <body>
      <h1>Sample Application</h1>
      
      <div ng-app = "">
         <p>Enter your Name: <input type = "text" ng-model = "name"></p>
         <p>Hello <span ng-bind = "name"></span>!</p>
      </div>
      
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Entrez votre nom et voyez le résultat.

Comment AngularJS s'intègre avec HTML

  • La directive ng-app indique le début de l'application AngularJS.

  • La directive ng-model crée alors une variable de modèle nommée "nom" qui peut être utilisée avec la page html et dans le div ayant la directive ng-app.

  • ng-bind utilise ensuite le modèle de nom à afficher dans la balise span html chaque fois que l'utilisateur saisit quelque chose dans la zone de texte.

  • La balise de fermeture </div> indique la fin de l'application AngularJS.

Les directives AngularJS sont utilisées pour étendre le HTML. Ce sont des attributs spéciaux commençant par le préfixe ng-. Nous allons discuter des directives suivantes -

  • ng-app - Cette directive démarre une application AngularJS.

  • ng-init - Cette directive initialise les données d'application.

  • ng-model - Cette directive lie les valeurs des données d'application AngularJS aux contrôles d'entrée HTML.

  • ng-repeat - Cette directive répète les éléments html pour chaque élément d'une collection.

directive ng-app

La directive ng-app démarre une application AngularJS. Il définit l'élément racine. Il initialise ou amorce automatiquement l'application lorsque la page Web contenant l'application AngularJS est chargée. Il est également utilisé pour charger divers modules AngularJS dans AngularJS Application. Dans l'exemple suivant, nous avons défini une application AngularJS par défaut à l'aide de l'attribut ng-app d'un élément div.

<div ng-app = "">
   ...
</div>

directive ng-init

La directive ng-init initialise les données d'une application AngularJS. Il est utilisé pour mettre des valeurs aux variables à utiliser dans l'application. Dans l'exemple suivant, nous initialiserons un tableau de pays. Nous utilisons la syntaxe JSON pour définir un tableau de pays.

<div ng-app = "" ng-init = "countries = [{locale:'en-US',name:'United States'}, 
   {locale:'en-GB',name:'United Kingdom'}, {locale:'en-FR',name:'France'}]">
   ...
</div>

directive ng-model

Cette directive lie les valeurs des données d'application AngularJS aux contrôles d'entrée HTML. Dans l'exemple suivant, nous avons défini un modèle nommé "nom".

<div ng-app = "">
   ...
   <p>Enter your Name: <input type = "text" ng-model = "name"></p>
</div>

directive ng-repeat

La directive ng-repeat répète les éléments html pour chaque élément d'une collection. Dans l'exemple suivant, nous avons parcouru un éventail de pays.

<div ng-app = "">
   ...
   <p>List of Countries with locale:</p>
   
   <ol>
      <li ng-repeat = "country in countries">
         {{ 'Country: ' + country.name + ', Locale: ' + country.locale }}
      </li>
   </ol>
</div>

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>AngularJS Directives</title>
   </head>
   
   <body>
      <h1>Sample Application</h1>
      
      <div ng-app = "" ng-init = "countries = [{locale:'en-US',name:'United States'}, 
         {locale:'en-GB',name:'United Kingdom'}, {locale:'en-FR',name:'France'}]"> 
         <p>Enter your Name: <input type = "text" ng-model = "name"></p>
         <p>Hello <span ng-bind = "name"></span>!</p>
         <p>List of Countries with locale:</p>
      
         <ol>
            <li ng-repeat = "country in countries">
               {{ 'Country: ' + country.name + ', Locale: ' + country.locale }}
            </li>
         </ol>
      </div>
      
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Entrez votre nom et voyez le résultat.

Les expressions sont utilisées pour lier les données d'application au html. Les expressions sont écrites entre accolades doubles comme {{expression}}. Les expressions se comportent de la même manière que les directives ng-bind. Les expressions d'application AngularJS sont des expressions javascript pures et produisent les données là où elles sont utilisées.

Utiliser des nombres

<p>Expense on Books : {{cost * quantity}} Rs</p>

Utiliser des chaînes

<p>Hello {{student.firstname + " " + student.lastname}}!</p>

Utilisation d'un objet

<p>Roll No: {{student.rollno}}</p>

Utilisation du tableau

<p>Marks(Math): {{marks[3]}}</p>

Exemple

L'exemple suivant présentera toutes les expressions mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>AngularJS Expressions</title>
   </head>
   
   <body>
      <h1>Sample Application</h1>
      
      <div ng-app = "" ng-init = "quantity = 1;cost = 30; 
         student = {firstname:'Mahesh',lastname:'Parashar',rollno:101};
         marks = [80,90,75,73,60]">
         <p>Hello {{student.firstname + " " + student.lastname}}!</p>
         <p>Expense on Books : {{cost * quantity}} Rs</p>
         <p>Roll No: {{student.rollno}}</p>
         <p>Marks(Math): {{marks[3]}}</p>
      </div>
      
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

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 contenant 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 contrôler.

<div ng-app = "" ng-controller = "studentController">
   ...
</div>

Ici, nous avons déclaré un contrôleur studentControlleren utilisant la directive ng-controller. Dans une prochaine étape, nous définirons le studentController 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>
  • studentController défini comme un objet JavaScript avec $ scope comme argument.

  • $ scope fait référence à l'application qui doit utiliser l'objet studentController.

  • $ scope.student est la propriété de l'objet studentController.

  • firstName et lastName sont deux propriétés de l'objet $ scope.student. Nous leur avons transmis les valeurs par défaut.

  • fullName est la fonction de l'objet $ scope.student dont la tâche est de renvoyer le nom combiné.

  • Dans la fonction fullName, nous obtenons l'objet étudiant, puis nous renvoyons le nom combiné.

  • À titre de note, 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 limité student.firstName et student.lastname à deux zones de saisie.

  • Nous avons lié student.fullName () au 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 montrera 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 textAngularJS.htm dans un navigateur Web. Voyez le résultat.

Les filtres sont utilisés pour modifier modifier les données et peuvent être matraqués dans une expression ou des directives en utilisant le caractère pipe. Voici la liste des filtres couramment utilisés.

Sr.No. Nom et description
1

uppercase

convertit un texte en texte majuscule.

2

lowercase

convertit un texte en texte minuscule.

3

currency

met en forme le texte dans un format monétaire.

4

filter

filtrer le tableau sur un sous-ensemble de celui-ci en fonction des critères fournis.

5

orderby

classe le tableau en fonction des critères fournis.

filtre en majuscules

Ajoutez un filtre en majuscules à une expression à l'aide du caractère pipe. Ici, nous avons ajouté un filtre en majuscules pour imprimer le nom de l'étudiant dans toutes les lettres majuscules.

Enter first name:<input type = "text" ng-model = "student.firstName">
Enter last name: <input type = "text" ng-model = "student.lastName">
Name in Upper Case: {{student.fullName() | uppercase}}

filtre en minuscules

Ajoutez un filtre en minuscules à une expression à l'aide du caractère pipe. Ici, nous avons ajouté un filtre en minuscules pour imprimer le nom de l'élève dans toutes les lettres minuscules.

Enter first name:<input type = "text" ng-model = "student.firstName">
Enter last name: <input type = "text" ng-model = "student.lastName">
Name in Lower Case: {{student.fullName() | lowercase}}

filtre de devises

Ajoutez un filtre de devise à une expression renvoyant un nombre à l'aide du caractère pipe. Ici, nous avons ajouté un filtre de devise pour imprimer les frais en utilisant le format de devise.

Enter fees: <input type = "text" ng-model = "student.fees">
fees: {{student.fees | currency}}

filtre filtre

Pour afficher uniquement les sujets obligatoires, nous avons utilisé subjectName comme filtre.

Enter subject: <input type = "text" ng-model = "subjectName">
Subject:
<ul>
   <li ng-repeat = "subject in student.subjects | filter: subjectName">
      {{ subject.name + ', marks:' + subject.marks }}
   </li>
</ul>

trier par filtre

Pour classer les sujets par marques, nous avons utilisé des marques orderBy.

Subject:
<ul>
   <li ng-repeat = "subject in student.subjects | orderBy:'marks'">
      {{ subject.name + ', marks:' + subject.marks }}
   </li>
</ul>

Exemple

L'exemple suivant présentera tous les filtres mentionnés ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Filters</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">
         <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>Enter fees: </td>
               <td><input type = "text" ng-model = "student.fees"></td>
            </tr>
            <tr>
               <td>Enter subject: </td>
               <td><input type = "text" ng-model = "subjectName"></td>
            </tr>
         </table>
         <br/>
         
         <table border = "0">
            <tr>
               <td>Name in Upper Case: </td><td>{{student.fullName() | uppercase}}</td>
            </tr>
            <tr>
               <td>Name in Lower Case: </td><td>{{student.fullName() | lowercase}}</td>
            </tr>
            <tr>
               <td>fees: </td><td>{{student.fees | currency}}
               </td>
            </tr>
            <tr>
               <td>Subject:</td>
               <td>
                  <ul>
                     <li ng-repeat = "subject in student.subjects | filter: subjectName |orderBy:'marks'">
                        {{ subject.name + ', marks:' + subject.marks }}
                     </li>
                  </ul>
               </td>
            </tr>
         </table>
      </div>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         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}
               ],
               
               fullName: function() {
                  var studentObject;
                  studentObject = $scope.student;
                  return studentObject.firstName + " " + studentObject.lastName;
               }
            };
         });
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

Les données de table sont normalement reproductibles par nature. La directive ng-repeat peut être utilisée pour dessiner facilement une table. L'exemple suivant indique l'utilisation de la directive ng-repeat pour dessiner un tableau.

<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>

Le tableau peut être stylisé à l'aide du style CSS.

<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>

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Table</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.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>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         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;
               }
            };
         });
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

Les directives suivantes peuvent être utilisées pour lier les données d'application aux attributs des éléments HTML DOM.

Sr.No. Nom et description
1

ng-disabled

désactive un contrôle donné.

2

ng-show

montre un contrôle donné.

3

ng-hide

cache un contrôle donné.

4

ng-click

représente un événement de clic AngularJS.

directive ng-disabled

Ajoutez l'attribut ng-disabled à un bouton HTML et passez-lui un modèle. Liez le modèle à une case à cocher et voyez la variation.

<input type = "checkbox" ng-model = "enableDisableButton">Disable Button
<button ng-disabled = "enableDisableButton">Click Me!</button>

directive ng-show

Ajoutez l'attribut ng-show à un bouton HTML et passez-lui un modèle. Liez le modèle à une case à cocher et voyez la variation.

<input type = "checkbox" ng-model = "showHide1">Show Button
<button ng-show = "showHide1">Click Me!</button>

directive ng-hide

Ajoutez l'attribut ng-hide à un bouton HTML et passez-lui un modèle. Liez le modèle à une case à cocher et voyez la variation.

<input type = "checkbox" ng-model = "showHide2">Hide Button
<button ng-hide = "showHide2">Click Me!</button>

directive ng-click

Ajoutez un attribut ng-click à un bouton HTML et mettez à jour un modèle. Liez le modèle au html et voyez la variation.

<p>Total click: {{ clickCounter }}</p>
<button ng-click = "clickCounter = clickCounter + 1">Click Me!</button>

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>AngularJS HTML DOM</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "">
         <table border = "0">
            <tr>
               <td><input type = "checkbox" ng-model = "enableDisableButton">Disable Button</td>
               <td><button ng-disabled = "enableDisableButton">Click Me!</button></td>
            </tr>
            
            <tr>
               <td><input type = "checkbox" ng-model = "showHide1">Show Button</td>
               <td><button ng-show = "showHide1">Click Me!</button></td>
            </tr>
            
            <tr>
               <td><input type = "checkbox" ng-model = "showHide2">Hide Button</td>
               <td><button ng-hide = "showHide2">Click Me!</button></td>
            </tr>
            
            <tr>
               <td><p>Total click: {{ clickCounter }}</p></td>
               <td><button ng-click = "clickCounter = clickCounter + 1">Click Me!</button></td>
            </tr>
         </table>
      </div>
      
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

AngularJS prend en charge l'approche modulaire. Les modules sont utilisés pour séparer les logiques (services, contrôleurs, applications, etc.) et garder le code propre. Nous définissons les modules dans des fichiers js séparés et les nommons selon le fichier module.js. Dans cet exemple, 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

mainApp.js

var mainApp = angular.module("mainApp", []);

Ici, nous avons déclaré une application mainAppmodule utilisant la fonction angular.module. Nous lui avons passé 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 avons déclaré 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 avons utilisé le module d'application utilisant la directive ng-app et le contrôleur utilisant la directive ng-controller. Nous avons importé mainApp.js et studentController.js dans la page html principale.

Exemple

L'exemple suivant présentera 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 textAngularJS.htm dans un navigateur Web. Voyez le résultat.

AngularJS enrichit le remplissage et la validation des formulaires. Nous pouvons utiliser ng-click pour gérer AngularJS cliquez sur le bouton et utiliser les indicateurs $ dirty et $ invalid pour faire les validations de manière apparente. Utilisez novalidate avec une déclaration de formulaire pour désactiver toute validation spécifique au navigateur. Les contrôles Forms font un usage intensif des événements angulaires. Jetons d'abord un coup d'œil sur les événements.

Événements

AngularJS fournit plusieurs événements qui peuvent être associés aux contrôles HTML. Par exemple, ng-click est normalement associé au bouton. Voici les événements pris en charge dans Angular JS.

  • ng-click
  • ng-dbl-click
  • ng-mousedown
  • ng-mouseup
  • ng-mouseenter
  • ng-mouseleave
  • ng-mousemove
  • ng-mouseover
  • ng-keydown
  • ng-keyup
  • ng-keypress
  • ng-change

ng-clic

Réinitialisez les données d'un formulaire à l'aide de la directive on-click d'un bouton.

<input name = "firstname" type = "text" ng-model = "firstName" required>
<input name = "lastname" type = "text" ng-model = "lastName" required>
<input name = "email" type = "email" ng-model = "email" required>
<button ng-click = "reset()">Reset</button>

<script>
   function studentController($scope) { 
      $scope.reset = function() {
         $scope.firstName = "Mahesh";
         $scope.lastName = "Parashar";
         $scope.email = "[email protected]";
      }   
      
      $scope.reset();
   }
</script>

Valider les données

Les éléments suivants peuvent être utilisés pour suivre les erreurs.

  • $dirty - indique que la valeur a été modifiée.

  • $invalid - indique que la valeur saisie n'est pas valide.

  • $error - indique l'erreur exacte.

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Forms</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.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">
         
         <form name = "studentForm" novalidate>
            <table border = "0">
               <tr>
                  <td>Enter first name:</td>
                  <td><input name = "firstname" type = "text" ng-model = "firstName" required>
                     <span style = "color:red" ng-show = "studentForm.firstname.$dirty && studentForm.firstname.$invalid">
                        <span ng-show = "studentForm.firstname.$error.required">First Name is required.</span>
                     </span>
                  </td>
               </tr>
               
               <tr>
                  <td>Enter last name: </td>
                  <td><input name = "lastname"  type = "text" ng-model = "lastName" required>
                     <span style = "color:red" ng-show = "studentForm.lastname.$dirty && studentForm.lastname.$invalid">
                        <span ng-show = "studentForm.lastname.$error.required">Last Name is required.</span>
                     </span>
                  </td>
               </tr>
               
               <tr>
                  <td>Email: </td><td><input name = "email" type = "email" ng-model = "email" length = "100" required>
                     <span style = "color:red" ng-show = "studentForm.email.$dirty && studentForm.email.$invalid">
                        <span ng-show = "studentForm.email.$error.required">Email is required.</span>
                        <span ng-show = "studentForm.email.$error.email">Invalid email address.</span>
                     </span>
                  </td>
               </tr>
               
               <tr>
                  <td>
                     <button ng-click = "reset()">Reset</button>
                  </td>
                  <td>
                     <button ng-disabled = "studentForm.firstname.$dirty &&
                        studentForm.firstname.$invalid || studentForm.lastname.$dirty &&
                        studentForm.lastname.$invalid || studentForm.email.$dirty &&
                        studentForm.email.$invalid" ng-click="submit()">Submit</button>
                  </td>
               </tr>
					
            </table>
         </form>
      </div>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller('studentController', function($scope) {
            $scope.reset = function() {
               $scope.firstName = "Mahesh";
               $scope.lastName = "Parashar";
               $scope.email = "[email protected]";
            }
            
            $scope.reset();
         });
      </script>
      
   </body>
</html>

Production

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

HTML ne prend pas en charge l'incorporation de pages html dans une page html. Pour obtenir cette fonctionnalité, les moyens suivants sont utilisés -

  • Using Ajax - Faites un appel au serveur pour obtenir la page html correspondante et définissez-la dans innerHTML du contrôle html.

  • Using Server Side Includes - JSP, PHP et d'autres technologies de serveur côté Web peuvent inclure des pages html dans une page dynamique.

En utilisant AngularJS, nous pouvons intégrer des pages HTML dans une page HTML à l'aide de la directive ng-include.

<div ng-app = "" ng-controller = "studentController">
   <div ng-include = "'main.htm'"></div>
   <div ng-include = "'subjects.htm'"></div>
</div>

Exemple

tryAngularJS.htm

<html>
   <head>
      <title>Angular JS Includes</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.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">
         <div ng-include = "'/angularjs/src/include/main.htm'"></div>
         <div ng-include = "'/angularjs/src/include/subjects.htm'"></div>
      </div>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         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;
               }
            };
         });
      </script>
      
   </body>
</html>

main.htm

<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>
</table>

subjects.htm

<p>Subjects:</p>
<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>

Production

Pour exécuter cet exemple, vous devez déployer textAngularJS.htm, main.htm et subjects.htm sur un serveur Web. Ouvrez textAngularJS.htm en utilisant l'URL de votre serveur dans un navigateur Web. Voyez le résultat.

AngularJS fournit $ https: contrôle qui fonctionne comme un service pour lire les données du serveur. Le serveur effectue un appel à la base de données pour obtenir les enregistrements souhaités. AngularJS a besoin de données au format JSON. Une fois que les données sont prêtes, $ https: peut être utilisé pour obtenir les données du serveur de la manière suivante -

function studentController($scope,$https:) {
   var url = "data.txt";

   $https:.get(url).success( function(response) {
      $scope.students = response; 
   });
}

Ici, le fichier data.txt contient les enregistrements des étudiants. $ https: le service effectue un appel ajax et définit la réponse à ses étudiants de propriété. Le modèle des élèves peut être utilisé pour dessiner des tableaux en HTML.

Exemples

data.txt

[
   {
      "Name" : "Mahesh Parashar",
      "RollNo" : 101,
      "Percentage" : "80%"
   },
	
   {
      "Name" : "Dinkar Kad",
      "RollNo" : 201,
      "Percentage" : "70%"
   },
	
   {
      "Name" : "Robert",
      "RollNo" : 191,
      "Percentage" : "75%"
   },
	
   {
      "Name" : "Julian Joe",
      "RollNo" : 111,
      "Percentage" : "77%"
   }
]

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Includes</title>
      
      <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 = "" ng-controller = "studentController">
      
         <table>
            <tr>
               <th>Name</th>
               <th>Roll No</th>
               <th>Percentage</th>
            </tr>
         
            <tr ng-repeat = "student in students">
               <td>{{ student.Name }}</td>
               <td>{{ student.RollNo }}</td>
               <td>{{ student.Percentage }}</td>
            </tr>
         </table>
      </div>
      
      <script>
         function studentController($scope,$http) {
            var url = "data.txt";

            $http.get(url).then( function(response) {
               $scope.students = response.data;
            });
         }
      </script>
      
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.js">
      </script>
      
   </body>
</html>

Production

Pour exécuter cet exemple, vous devez déployer le fichier testAngularJS.htm et data.txt sur un serveur Web. Ouvrez le fichier testAngularJS.htm en utilisant l'URL de votre serveur dans un navigateur Web et voyez le résultat.

AngularJS prend en charge l'application à page unique via plusieurs vues sur une seule page. Pour ce faire, AngularJS a fourni les directives ng-view et ng-template et les services $ routeProvider.

ng-view

La balise ng-view crée simplement un espace réservé où une vue correspondante (vue html ou ng-template) peut être placée en fonction de la configuration.

Usage

Définissez un div avec ng-view dans le module principal.

<div ng-app = "mainApp">
   ...
   <div ng-view></div>

</div>

ng-template

La directive ng-template est utilisée pour créer une vue html à l'aide d'une balise script. Il contient l'attribut "id" qui est utilisé par $ routeProvider pour mapper une vue avec un contrôleur.

Usage

Définissez un bloc de script avec le type comme ng-template dans le module principal.

<div ng-app = "mainApp">
   ...
	
   <script type = "text/ng-template" id = "addStudent.htm">
      <h2> Add Student </h2>
      {{message}}
   </script>

</div>

$ routeProvider

$ routeProvider est le service clé qui définit la configuration des URL, les mappe avec la page html ou ng-template correspondante, et attache un contrôleur avec le même.

Usage

Définissez un bloc de script avec le module principal et définissez la configuration de routage.

var mainApp = angular.module("mainApp", ['ngRoute']);

mainApp.config(['$routeProvider', function($routeProvider) {
   $routeProvider
   
   .when('/addStudent', {
      templateUrl: 'addStudent.htm', controller: 'AddStudentController'
   })
   
   .when('/viewStudents', {
      templateUrl: 'viewStudents.htm', controller: 'ViewStudentsController'
   })
   
   .otherwise ({
      redirectTo: '/addStudent'
   });
	
}]);

Voici les points importants à considérer dans l'exemple ci-dessus.

  • $ routeProvider est défini comme une fonction sous la configuration du module mainApp en utilisant la clé comme '$ routeProvider'.

  • $ routeProvider.when définit une url "/ addStudent" qui est ensuite mappée sur "addStudent.htm". addStudent.htm doit être présent dans le même chemin que la page html principale. Si la page htm n'est pas définie, alors ng-template à utiliser avec id = "addStudent.htm". Nous avons utilisé ng-template.

  • «Sinon» est utilisé pour définir la vue par défaut.

  • "controller" est utilisé pour définir le contrôleur correspondant pour la vue.

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Views</title>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular-route.min.js">
      </script>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      <div ng-app = "mainApp">
         <p><a href = "#addStudent">Add Student</a></p>
         <p><a href = "#viewStudents">View Students</a></p>
         <div ng-view></div>
         
         <script type = "text/ng-template" id = "addStudent.htm">
            <h2> Add Student </h2>
            {{message}}
         </script>
         
         <script type = "text/ng-template" id = "viewStudents.htm">
            <h2> View Students </h2>
            {{message}}
         </script>
      </div>
      
      <script>
         var mainApp = angular.module("mainApp", ['ngRoute']);
         mainApp.config(['$routeProvider', function($routeProvider) {
            $routeProvider
            
            .when('/addStudent', {
               templateUrl: 'addStudent.htm',
               controller: 'AddStudentController'
            })
            
            .when('/viewStudents', {
               templateUrl: 'viewStudents.htm',
               controller: 'ViewStudentsController'
            })
            
            .otherwise({
               redirectTo: '/addStudent'
            });
         }]);
         
         mainApp.controller('AddStudentController', function($scope) {
            $scope.message = "This page will be used to display add student form";
         });
         
         mainApp.controller('ViewStudentsController', function($scope) {
            $scope.message = "This page will be used to display all the students";
         });
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

Scope est un objet javascript spécial qui joue le rôle de relier le contrôleur aux vues. Scope contient les données du modèle. Dans les contrôleurs, les données du modèle sont accessibles via l'objet $ scope.

<script>
   var mainApp = angular.module("mainApp", []);
   
   mainApp.controller("shapeController", function($scope) {
      $scope.message = "In shape controller";
      $scope.type = "Shape";
   });
</script>

Voici les points importants à considérer dans l'exemple ci-dessus.

  • $ scope est passé comme premier argument au contrôleur lors de sa définition du constructeur.

  • $ scope.message et $ scope.type sont les modèles à utiliser dans la page HTML.

  • Nous avons défini les valeurs des modèles qui seront reflétées dans le module d'application dont le contrôleur est shapeController.

  • Nous pouvons également définir des fonctions dans $ scope.

Héritage d'étendue

La portée est spécifique aux contrôleurs. Si nous définissons des contrôleurs imbriqués, le contrôleur enfant héritera de la portée de son contrôleur parent.

<script>
   var mainApp = angular.module("mainApp", []);
   
   mainApp.controller("shapeController", function($scope) {
      $scope.message = "In shape controller";
      $scope.type = "Shape";
   });
   
   mainApp.controller("circleController", function($scope) {
      $scope.message = "In circle controller";
   });
	
</script>

Voici les points importants à considérer dans l'exemple ci-dessus.

  • Nous avons défini des valeurs pour les modèles dans shapeController.

  • Nous avons remplacé le message dans le contrôleur enfant circleController. Lorsque "message" est utilisé dans le module du contrôleur circleController, le message annulé sera utilisé.

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Forms</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "shapeController">
         <p>{{message}} <br/> {{type}} </p>
         
         <div ng-controller = "circleController">
            <p>{{message}} <br/> {{type}} </p>
         </div>
         
         <div ng-controller = "squareController">
            <p>{{message}} <br/> {{type}} </p>
         </div>
			
      </div>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller("shapeController", function($scope) {
            $scope.message = "In shape controller";
            $scope.type = "Shape";
         });
         
         mainApp.controller("circleController", function($scope) {
            $scope.message = "In circle controller";
         });
         
         mainApp.controller("squareController", function($scope) {
            $scope.message = "In square controller";
            $scope.type = "Square";
         });
			
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

AngularJS prend en charge les concepts de «séparation des préoccupations» en utilisant l'architecture des services. Les services sont des fonctions javascript et sont chargés d'effectuer une tâche spécifique uniquement. Cela en fait une entité individuelle qui est maintenable et testable. Les contrôleurs, les filtres peuvent les appeler comme sur la base des besoins. Les services sont normalement injectés à l'aide du mécanisme d'injection de dépendances d'AngularJS.

AngularJS fournit de nombreux services intégrés, par exemple $ https :, $ route, $ window, $ location etc. Chaque service est responsable d'une tâche spécifique, par exemple $ https: est utilisé pour faire un appel ajax pour obtenir les données du serveur. $ route est utilisé pour définir les informations de routage et ainsi de suite. Les services intégrés sont toujours précédés du symbole $.

Il existe deux façons de créer un service.

  • factory
  • service

En utilisant la méthode d'usine

En utilisant la méthode de l'usine, nous définissons d'abord une usine, puis nous lui attribuons une méthode.

var mainApp = angular.module("mainApp", []);
mainApp.factory('MathService', function() {
   var factory = {};
   
   factory.multiply = function(a, b) {
      return a * b
   }
   
   return factory;
});

Utilisation de la méthode de service

En utilisant la méthode de service, nous définissons un service, puis nous lui attribuons une méthode. Nous y avons également injecté un service déjà disponible.

mainApp.service('CalcService', function(MathService) {
   this.square = function(a) {
      return MathService.multiply(a,a);
   }
});

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Services</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 = "CalcController">
         <p>Enter a number: <input type = "number" ng-model = "number" /></p>
         <button ng-click = "square()">X<sup>2</sup></button>
         <p>Result: {{result}}</p>
      </div>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.factory('MathService', function() {
            var factory = {};
            
            factory.multiply = function(a, b) {
               return a * b
            }
            return factory;
         });
         
         mainApp.service('CalcService', function(MathService) {
            this.square = function(a) {
               return MathService.multiply(a,a);
            }
         });
         
         mainApp.controller('CalcController', function($scope, CalcService) {
            $scope.square = function() {
               $scope.result = CalcService.square($scope.number);
            }
         });
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

L'injection de dépendances est un modèle de conception logicielle dans lequel les composants reçoivent leurs dépendances au lieu de les coder en dur dans le composant. Cela évite à un composant de localiser la dépendance et rend les dépendances configurables. Cela aide à rendre les composants réutilisables, maintenables et testables.

AngularJS fournit un mécanisme d'injection de dépendance suprême. Il fournit les composants de base suivants qui peuvent être injectés les uns dans les autres en tant que dépendances.

  • value
  • factory
  • service
  • provider
  • constant

valeur

value est un simple objet javascript et il est utilisé pour transmettre des valeurs au contrôleur pendant la phase de configuration.

//define a module
var mainApp = angular.module("mainApp", []);

//create a value object as "defaultInput" and pass it a data.
mainApp.value("defaultInput", 5);
...

//inject the value in the controller using its name "defaultInput"
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
   $scope.number = defaultInput;
   $scope.result = CalcService.square($scope.number);
   
   $scope.square = function() {
      $scope.result = CalcService.square($scope.number);
   }
});

usine

factory est une fonction utilisée pour renvoyer une valeur. Il crée de la valeur à la demande chaque fois qu'un service ou un contrôleur l'exige. Il utilise normalement une fonction d'usine pour calculer et renvoyer la valeur.

//define a module
var mainApp = angular.module("mainApp", []);

//create a factory "MathService" which provides a method multiply to return multiplication of two numbers
mainApp.factory('MathService', function() {
   var factory = {};
   
   factory.multiply = function(a, b) {
      return a * b
   }
   return factory;
}); 

//inject the factory "MathService" in a service to utilize the multiply method of factory.
mainApp.service('CalcService', function(MathService) {
   this.square = function(a) {
      return MathService.multiply(a,a);
   }
});
...

un service

service est un objet javascript singleton contenant un ensemble de fonctions pour effectuer certaines tâches. Les services sont définis à l'aide des fonctions service () puis injectés dans les contrôleurs.

//define a module
var mainApp = angular.module("mainApp", []);
...

//create a service which defines a method square to return square of a number.
mainApp.service('CalcService', function(MathService) {
   this.square = function(a) {
      return MathService.multiply(a,a); 
   }
});

//inject the service "CalcService" into the controller
mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
   $scope.number = defaultInput;
   $scope.result = CalcService.square($scope.number);
   
   $scope.square = function() {
      $scope.result = CalcService.square($scope.number);
   }
});

fournisseur

Le fournisseur est utilisé par AngularJS en interne pour créer des services, une usine, etc. pendant la phase de configuration (phase pendant laquelle AngularJS s'amorce). Le script de mention ci-dessous peut être utilisé pour créer MathService que nous avons créé précédemment. Provider est une méthode de fabrique spéciale avec une méthode get () qui est utilisée pour renvoyer la valeur / service / usine.

//define a module
var mainApp = angular.module("mainApp", []);
...

//create a service using provider which defines a method square to return square of a number.
mainApp.config(function($provide) {
   $provide.provider('MathService', function() {
      this.$get = function() {
         var factory = {};  
         
         factory.multiply = function(a, b) {
            return a * b; 
         }
         return factory;
      };
   });
});

constant

Les constantes sont utilisées pour transmettre des valeurs à la phase de configuration compte tenu du fait que la valeur ne peut pas être utilisée pour être transmise pendant la phase de configuration.

mainApp.constant("configParam", "constant value");

Exemple

L'exemple suivant présentera toutes les directives mentionnées ci-dessus.

testAngularJS.htm

<html>
   <head>
      <title>AngularJS Dependency Injection</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "CalcController">
         <p>Enter a number: <input type = "number" ng-model = "number" /></p>
         <button ng-click = "square()">X<sup>2</sup></button>
         <p>Result: {{result}}</p>
      </div>
      
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.config(function($provide) {
            $provide.provider('MathService', function() {
               this.$get = function() {
                  var factory = {};
                  
                  factory.multiply = function(a, b) {
                     return a * b;
                  }
                  return factory;
               };
            });
         });
			
         mainApp.value("defaultInput", 5);
         
         mainApp.factory('MathService', function() {
            var factory = {};
            
            factory.multiply = function(a, b) {
               return a * b;
            }
            return factory;
         });
         
         mainApp.service('CalcService', function(MathService) {
            this.square = function(a) {
               return MathService.multiply(a,a);
            }
         });
         
         mainApp.controller('CalcController', function($scope, CalcService, defaultInput) {
            $scope.number = defaultInput;
            $scope.result = CalcService.square($scope.number);

            $scope.square = function() {
               $scope.result = CalcService.square($scope.number);
            }
         });
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

Les directives personnalisées sont utilisées dans AngularJS pour étendre les fonctionnalités de HTML. Les directives personnalisées sont définies à l'aide de la fonction "directive". Une directive personnalisée remplace simplement l'élément pour lequel elle est activée. L'application AngularJS lors du bootstrap trouve les éléments correspondants et effectue une activité ponctuelle en utilisant sa méthode compile () de la directive personnalisée, puis traite l'élément en utilisant la méthode link () de la directive personnalisée en fonction de la portée de la directive. AngularJS prend en charge la création de directives personnalisées pour les types d'éléments suivants.

  • Element directives - La directive s'active lorsqu'un élément correspondant est rencontré.

  • Attribute - La directive s'active lorsqu'un attribut correspondant est rencontré.

  • CSS - La directive s'active lorsqu'un style css correspondant est rencontré.

  • Comment - La directive s'active lorsqu'un commentaire correspondant est rencontré.

Comprendre la directive personnalisée

Définissez des balises HTML personnalisées.

<student name = "Mahesh"></student><br/>
<student name = "Piyush"></student>

Définissez la directive personnalisée pour gérer les balises HTML personnalisées ci-dessus.

var mainApp = angular.module("mainApp", []);

//Create a directive, first parameter is the html element to be attached.	  
//We are attaching student html tag. 
//This directive will be activated as soon as any student element is encountered in html

mainApp.directive('student', function() {
   //define the directive object
   var directive = {};
   
   //restrict = E, signifies that directive is Element directive
   directive.restrict = 'E';
   
   //template replaces the complete element with its text. 
   directive.template = "Student: <b>{{student.name}}</b> , 
      Roll No: <b>{{student.rollno}}</b>";
   
   //scope is used to distinguish each student element based on criteria.
   directive.scope = {
      student : "=name"
   }
   
   //compile is called during application initialization. AngularJS calls 
      it once when html page is loaded.
	
   directive.compile = function(element, attributes) {
      element.css("border", "1px solid #cccccc");
      
      //linkFunction is linked with each element with scope to get the element specific data.
      var linkFunction = function($scope, element, attributes) {
         element.html("Student: <b>"+$scope.student.name +"</b> , 
            Roll No: <b>"+$scope.student.rollno+"</b><br/>");
         element.css("background-color", "#ff00ff");
      }
      return linkFunction;
   }
   
   return directive;
});

Définissez le contrôleur pour mettre à jour la portée de la directive. Ici, nous utilisons la valeur de l'attribut name comme enfant de la portée.

mainApp.controller('StudentController', function($scope) {
   $scope.Mahesh = {};
   $scope.Mahesh.name = "Mahesh Parashar";
   $scope.Mahesh.rollno  = 1;
   
   $scope.Piyush = {};
   $scope.Piyush.name = "Piyush Parashar";
   $scope.Piyush.rollno  = 2;
});

Exemple

<html>
   <head>
      <title>Angular JS Custom Directives</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "StudentController">
         <student name = "Mahesh"></student><br/>
         <student name = "Piyush"></student>
      </div>
		
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.directive('student', function() {
            var directive = {};
            directive.restrict = 'E';
            directive.template = "Student: <b>{{student.name}}</b> , 
               Roll No: <b>{{student.rollno}}</b>";
            
            directive.scope = {
               student : "=name"
            }
            
            directive.compile = function(element, attributes) {
               element.css("border", "1px solid #cccccc");
               
               var linkFunction = function($scope, element, attributes) {
                  element.html("Student: <b>"+$scope.student.name +"</b> , 
                     Roll No: <b>"+$scope.student.rollno+"</b><br/>");
                  element.css("background-color", "#ff00ff");
               }
               return linkFunction;
            }
            
            return directive;
         });
         
         mainApp.controller('StudentController', function($scope) {
            $scope.Mahesh = {};
            $scope.Mahesh.name = "Mahesh Parashar";
            $scope.Mahesh.rollno  = 1;

            $scope.Piyush = {};
            $scope.Piyush.name = "Piyush Parashar";
            $scope.Piyush.rollno  = 2;
         });
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

AngularJS prend en charge l'internationalisation intégrée pour trois types de filtres devise, date et nombres. Nous avons seulement besoin d'incorporer les js correspondants en fonction des paramètres régionaux du pays. Par défaut, il gère les paramètres régionaux du navigateur. Par exemple, pour utiliser les paramètres régionaux danois, utilisez le script suivant.

<script src = "https://code.angularjs.org/1.2.5/i18n/angular-locale_da-dk.js">
</script>

Exemple utilisant les paramètres régionaux danois

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Forms</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "StudentController">
         {{fees | currency }}  <br/><br/>
         {{admissiondate | date }}  <br/><br/>
         {{rollno | number }}
      </div>
		
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      <script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
      </script>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller('StudentController', function($scope) {
            $scope.fees = 100;
            $scope.admissiondate  = new Date();
            $scope.rollno = 123.45;
         });
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

Exemple d'utilisation des paramètres régionaux du navigateur

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Forms</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "StudentController">
         {{fees | currency }}  <br/><br/>
         {{admissiondate | date }}  <br/><br/>
         {{rollno | number }}
      </div>
		
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      <!-- <script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
      </script> -->
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller('StudentController', function($scope) {
            $scope.fees = 100;
            $scope.admissiondate  = new Date();
            $scope.rollno = 123.45;
         });
      </script>
      
   </body>
</html>

Résultat

Ouvrez textAngularJS.htm dans un navigateur Web. Voyez le résultat.

AngularJS prend en charge l'internationalisation intégrée pour trois types de filtres: devise, date et nombres. Nous avons seulement besoin d'incorporer le script java correspondant en fonction des paramètres régionaux du pays. Par défaut, il prend en compte les paramètres régionaux du navigateur. Par exemple, pour les paramètres régionaux danois, utilisez le script suivant -

<script src = "https://code.angularjs.org/1.2.5/i18n/angular-locale_da-dk.js">
</script>

Exemple d'utilisation des paramètres régionaux danois

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Forms</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "StudentController">
         {{fees | currency }}  <br/><br/>
         {{admissiondate | date }}  <br/><br/>
         {{rollno | number }}
      </div>
		
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      <script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
      </script>
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller('StudentController', function($scope) {
            $scope.fees = 100;
            $scope.admissiondate  = new Date();
            $scope.rollno = 123.45;
         });
      </script>
      
   </body>
</html>

Production

Ouvrez le fichier testAngularJS.htm dans un navigateur Web et voyez le résultat.

Exemple d'utilisation des paramètres régionaux du navigateur

testAngularJS.htm

<html>
   <head>
      <title>Angular JS Forms</title>
   </head>
   
   <body>
      <h2>AngularJS Sample Application</h2>
      
      <div ng-app = "mainApp" ng-controller = "StudentController">
         {{fees | currency }}  <br/><br/>
         {{admissiondate | date }}  <br/><br/>
         {{rollno | number }}
      </div>
		
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.3.14/angular.min.js">
      </script>
      <!-- <script src = "https://code.angularjs.org/1.3.14/i18n/angular-locale_da-dk.js">
      </script> -->
      
      <script>
         var mainApp = angular.module("mainApp", []);
         
         mainApp.controller('StudentController', function($scope) {
            $scope.fees = 100;
            $scope.admissiondate  = new Date();
            $scope.rollno = 123.45;
         });
      </script>
      
   </body>
</html>

Production

Ouvrez le fichier testAngularJS.htm dans un navigateur Web et voyez le résultat.