Matériau angulaire - Guide rapide

Angular Material est une bibliothèque de composants d'interface utilisateur pour les développeurs Angular JS. Les composants d'interface utilisateur réutilisables d'Angular Material aident à créer des pages Web et des applications Web attrayantes, cohérentes et fonctionnelles tout en adhérant aux principes de conception Web modernes tels que la portabilité du navigateur, l'indépendance des appareils et la dégradation gracieuse.

Voici quelques caractéristiques saillantes du matériau angulaire -

  • Conception réactive intégrée.

  • CSS standard avec une empreinte minimale.

  • Inclut de nouvelles versions de contrôles d'interface utilisateur courants tels que des boutons, des cases à cocher et des champs de texte qui sont adaptés pour suivre les concepts de Material Design.

  • Comprend des fonctionnalités améliorées et spécialisées telles que les cartes, la barre d'outils, la numérotation abrégée, la navigation latérale, le balayage, etc.

  • Cross-browser, et peut être utilisé pour créer des composants Web réutilisables.

Conception réactive

  • Angular Material a une conception réactive intégrée afin que le site Web créé à l'aide de Angular Material se redessine en fonction de la taille de l'appareil.

  • Les classes de matériaux angulaires sont créées de manière à ce que le site Web puisse s'adapter à n'importe quelle taille d'écran.

  • Les sites Web créés à l'aide du matériau angulaire sont entièrement compatibles avec les PC, les tablettes et les appareils mobiles.

Extensible

  • Le matériau angulaire est de par sa conception très minimal et plat.

  • Il est conçu en tenant compte du fait qu'il est beaucoup plus facile d'ajouter de nouvelles règles CSS que d'écraser les règles CSS existantes.

  • Il prend en charge les ombres et les couleurs vives.

  • Les couleurs et les nuances restent uniformes sur diverses plates-formes et appareils.

Et le plus important de tous, Angular Material est totalement gratuit.

Comment utiliser un matériau angulaire?

Il existe deux façons d'utiliser le matériau angulaire -

  • Local Installation - Vous pouvez télécharger les bibliothèques de matériaux angulaires en utilisant npm, jspm ou bower sur votre machine locale et l'inclure dans votre code HTML.

  • CDN Based Version - Vous pouvez inclure les fichiers angular-material.min.css et angular-material js dans votre code HTML directement à partir du Content Delivery Network (CDN).

Installation locale

Avant d'utiliser la commande npm suivante, nous avons besoin de l'installation de NodeJS sur notre système. Pour obtenir des informations sur le nœud JS, cliquez ici et ouvrez l'interface de ligne de commande NodeJS. Nous utiliserons la commande suivante pour installer les bibliothèques de matériaux angulaires.

npm install angular-material

La commande ci-dessus générera la sortie suivante -

[email protected] node_modules\angular-animate

[email protected] node_modules\angular-aria

[email protected] node_modules\angular-messages

[email protected] node_modules\angular

[email protected] node_modules\angular-material

npm téléchargera les fichiers sous node_modules > angular-materialdossier. Incluez les fichiers comme expliqué dans l'exemple suivant -

Exemple

Vous pouvez maintenant inclure le fichier css et js dans votre fichier HTML comme suit -

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      
      <script type = "text/javascript">    
         angular.module('firstApplication', ['ngMaterial']);
      </script>
   </head>
   
   <body ng-app = "firstApplication" ng-cloak>
      <md-toolbar class = "md-warn">
         <div class = "md-toolbar-tools">
            <h2 class = "md-flex">HTML 5</h2>
         </div>
      </md-toolbar>
      
      <md-content flex layout-padding>
         <p>HTML5 is the next major revision of the HTML standard superseding HTML
         4.01, XHTML 1.0, and XHTML 1.1. HTML5 is a standard for structuring and
         presenting content on the World Wide Web.</p>
         
         <p>HTML5 is a cooperation between the World Wide Web Consortium (W3C) and
         the Web Hypertext Application Technology Working Group (WHATWG).</p>
         
         <p>The new standard incorporates features like video playback and drag-and-drop
         that have been previously dependent on third-party browser plug-ins such as
         Adobe Flash, Microsoft Silverlight, and Google Gears.</p>
      </md-content>
   </body>
</html>

Le programme ci-dessus générera le résultat suivant -

Version basée sur CDN

Vous pouvez inclure le angular-material.css et angular-material.jsfichiers dans votre code HTML directement à partir du réseau de diffusion de contenu (CDN). Google CDN fournit du contenu pour la dernière version.

Nous utilisons la version Google CDN de la bibliothèque tout au long de ce didacticiel.

Exemple

Maintenant, réécrivons l'exemple ci-dessus en utilisant angular-material.min.css et angular-material.min.js de Google CDN.

<html lang = "en" >
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>

      <script type = "text/javascript">    
         angular.module('firstApplication', ['ngMaterial']);
      </script>
   </head>
   
   <body ng-app = "firstApplication" ng-cloak>
      <md-toolbar class = "md-warn">
         <div class = "md-toolbar-tools">
            <h2 class = "md-flex">HTML 5</h2>
         </div>
      </md-toolbar>
      
      <md-content flex layout-padding>
         <p>HTML5 is the next major revision of the HTML standard superseding HTML 4.01,
         XHTML 1.0, and XHTML 1.1. HTML5 is a standard for structuring and presenting 
         content on the World Wide Web.</p>

         <p>HTML5 is a cooperation between the World Wide Web Consortium (W3C) and the Web
         ypertext Application Technology Working Group (WHATWG).</p>
         
         <p>The new standard incorporates features like video playback and drag-and-drop
         that have been previously dependent on third-party browser plug-ins such as Adobe
         Flash, Microsoft Silverlight, and Google Gears.</p>
      </md-content>
   </body>
</html>

Le programme ci-dessus générera le résultat suivant -

le md-autocomplete, une directive angulaire, est utilisée comme contrôle d'entrée spécial avec une liste déroulante intégrée pour afficher toutes les correspondances possibles à une requête personnalisée. Ce contrôle agit comme une boîte à suggestions en temps réel dès que l'utilisateur tape dans la zone de saisie.<md-autocomplete>peut être utilisé pour fournir des résultats de recherche à partir de sources de données locales ou distantes. md-autocomplete met en cache les résultats lors de l'exécution d'une requête. Après le premier appel, il utilise les résultats mis en cache pour éliminer les demandes de serveur inutiles ou la logique de recherche et il peut être désactivé.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-autocomplete.

Sr. Non Paramètre et description
1

* md-items

Une expression au format d'élément dans les éléments pour parcourir les correspondances pour votre recherche.

2

md-selected-item-change

Une expression à exécuter chaque fois qu'un nouvel élément est sélectionné.

3

md-search-text-change

Une expression à exécuter à chaque mise à jour du texte de recherche.

4

md-search-text

Un modèle auquel lier le texte de la requête de recherche.

5

md-selected-item

Un modèle auquel lier l'élément sélectionné.

6

md-item-text

Une expression qui convertira votre objet en une seule chaîne.

sept

placeholder

Texte d'espace réservé qui sera transmis à l'entrée.

8

md-no-cache

Désactive la mise en cache interne qui se produit lors de la saisie semi-automatique.

9

ng-disabled

Détermine s'il faut désactiver ou non le champ de saisie.

dix

md-min-length

Spécifie la longueur minimale du texte avant que la saisie semi-automatique ne fasse des suggestions.

11

md-delay

Spécifie la durée (en millisecondes) à attendre avant de rechercher des résultats.

12

md-autofocus

Si vrai, focalisera immédiatement l'élément d'entrée.

13

md-autoselect

Si vrai, le premier élément sera sélectionné par défaut.

14

md-menu-class

Cela sera appliqué au menu déroulant pour le style.

15

md-floating-label

Cela ajoutera une étiquette flottante à la saisie semi-automatique et l'enveloppera dans le md-input-container.

16

md-input-name

L'attribut name donné à l'élément d'entrée à utiliser avec le FormController.

17

md-input-id

Un identifiant à ajouter à l'élément d'entrée.

18

md-input-minlength

La longueur minimale de la valeur d'entrée pour la validation.

19

md-input-maxlength

La longueur maximale de la valeur d'entrée pour la validation.

20

md-select-on-match

Lorsqu'elle est définie sur true, la saisie semi-automatique sélectionne automatiquement l'élément exact si le texte de recherche correspond exactement.

Exemple

L'exemple suivant montre l'utilisation du md-autocomplete directive et aussi l'utilisation de la saisie semi-automatique.

am_autocomplete.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('autoCompleteController', autoCompleteController);

         function autoCompleteController ($timeout, $q, $log) {
            var self = this;
            self.simulateQuery = false;
            self.isDisabled    = false;
            
            // list of states to be displayed
            self.states        = loadStates();
            self.querySearch   = querySearch;
            self.selectedItemChange = selectedItemChange;
            self.searchTextChange   = searchTextChange;
            self.newState = newState;
            
            function newState(state) {
               alert("This functionality is yet to be implemented!");
            }
            
            function querySearch (query) {
               var results = query ? self.states.filter( createFilterFor(query) ) :
                  self.states, deferred;
                  
               if (self.simulateQuery) {
                  deferred = $q.defer();
                     
                  $timeout(function () { 
                     deferred.resolve( results ); 
                  }, 
                  Math.random() * 1000, false);
                  return deferred.promise;
               } else {
                  return results;
               }
            }
            
            function searchTextChange(text) {
               $log.info('Text changed to ' + text);
            }
            
            function selectedItemChange(item) {
               $log.info('Item changed to ' + JSON.stringify(item));
            }
            
            //build list of states as map of key-value pairs
            function loadStates() {
               var allStates = 'Alabama, Alaska, Arizona, Arkansas, California, Colorado, Connecticut, Delaware,\
                  Florida, Georgia, Hawaii, Idaho, Illinois, Indiana, Iowa, Kansas, Kentucky, Louisiana,\
                  Maine, Maryland, Massachusetts, Michigan, Minnesota, Mississippi, Missouri, Montana,\
                  Nebraska, Nevada, New Hampshire, New Jersey, New Mexico, New York, North Carolina,\
                  North Dakota, Ohio, Oklahoma, Oregon, Pennsylvania, Rhode Island, South Carolina,\
                  South Dakota, Tennessee, Texas, Utah, Vermont, Virginia, Washington, West Virginia,\
                  Wisconsin, Wyoming';
                  
               return allStates.split(/, +/g).map( function (state) {
                  return {
                     value: state.toLowerCase(),
                     display: state
                  };
               });
            }
            
            //filter function for search query
            function createFilterFor(query) {
               var lowercaseQuery = angular.lowercase(query);
               return function filterFn(state) {
                  return (state.value.indexOf(lowercaseQuery) === 0);
               };
            }
         }  
      </script>      
   </head>
   
   <body ng-app = "firstApplication" ng-cloak>
      <div ng-controller = "autoCompleteController as ctrl" layout = "column" ng-cloak>
         <md-content class = "md-padding">
            <form ng-submit = "$event.preventDefault()">
               <p><code>md-autocomplete</code> can be used to provide search results from
               local or remote data sources.</p>
               
               <md-autocomplete
                  ng-disabled = "ctrl.isDisabled"
                  md-no-cache = "ctrl.noCache"
                  md-selected-item = "ctrl.selectedItem"
                  md-search-text-change = "ctrl.searchTextChange(ctrl.searchText)"
                  md-search-text = "ctrl.searchText"
                  md-selected-item-change = "ctrl.selectedItemChange(item)"
                  md-items = "item in ctrl.querySearch(ctrl.searchText)"
                  md-item-text = "item.display"
                  md-min-length = "0"
                  placeholder = "US State?">
                  
                  <md-item-template>
                     <span md-highlight-text = "ctrl.searchText"
                        md-highlight-flags = "^i">{{item.display}}</span>
                  </md-item-template>
                  
                  <md-not-found>
                     No states matching "{{ctrl.searchText}}" were found.
                     <a ng-click = "ctrl.newState(ctrl.searchText)">Create a new one!</a>
                  </md-not-found>
               </md-autocomplete>
               <br/>
               
               <md-checkbox ng-model = "ctrl.simulateQuery">Show progress for results?
                  </md-checkbox>
               <md-checkbox ng-model = "ctrl.noCache">Disable caching?</md-checkbox>
               <md-checkbox ng-model = "ctrl.isDisabled">Disable?</md-checkbox>
               <p><code>md-autocomplete</code> caches results when performing a query.
               After first call, it uses the cached results to eliminate unnecessary
               server requests or lookup logic and it can be disabled.</p>
            </form>
         </md-content>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le $mdBottomSheet, un service angulaire, est utilisé pour ouvrir une feuille inférieure sur l'application et fournit une API de promesse simple.

SN Méthode et description
1

$mdBottomSheet.show(options);

Afficher une feuille inférieure avec les options spécifiées.

SN Paramètre et description
1

* options

Un objet d'options, avec les propriétés suivantes -

  • templateUrl - {string=}- L'url d'un fichier modèle html qui sera utilisé comme contenu de la feuille du bas. Restrictions: le modèle doit avoir un élément extérieur md-bottom-sheet.

  • template - {string=} - Identique à templateUrl, sauf qu'il s'agit d'une chaîne de modèle réelle.

  • scope - {object=}- La portée à laquelle lier le modèle / contrôleur. Si aucun n'est spécifié, il créera une nouvelle portée enfant. Cette étendue sera détruite lorsque la feuille du bas est supprimée, sauf si PreserveScope est défini sur true.

  • preserveScope - {boolean=}- Il dicte s'il faut conserver la portée lorsque l'élément est supprimé. Par défaut, il est faux.

  • controller - {string=} - Le contrôleur à associer à ce bas de page.

  • locals - {string=}- Un objet contenant des paires clé / valeur. Les clés seront utilisées comme noms de valeurs à injecter dans le contrôleur. Par exemple,locals: {three: 3} injectera trois dans le contrôleur avec la valeur de 3.

  • clickOutsideToClose - {boolean=}- Il dicte si l'utilisateur peut cliquer en dehors de la feuille inférieure pour la fermer. Par défaut, c'est vrai.

  • escapeToClose - {boolean =}: il détermine si l'utilisateur peut appuyer sur échapper pour fermer la feuille du bas. Par défaut, c'est vrai.

  • resolve - {object=} - Similaire aux locaux, sauf que cela prend des promesses comme valeurs et la feuille du bas ne s'ouvrira pas tant que les promesses ne seront pas résolues.

  • controllerAs - {string =}: un alias auquel attribuer le contrôleur sur la portée.

  • parent - {element=}- L'élément auquel ajouter la feuille du bas. Le parent peut être une fonction, une chaîne, un objet ou une valeur nulle. Par défaut, il ajoute au corps de l'élément racine (ou de l'élément racine) de l'application. par exemple angular.element (document.getElementById ('content')) ou "#content".

  • disableParentScroll - {boolean=}- S'il faut désactiver le défilement lorsque la feuille du bas est ouverte. Valeur par défaut true.

Sr. Non Retours et description
1

promise

Une promesse qui peut être résolue avec $ mdBottomSheet.hide () ou rejetée avec $ mdBottomSheet.cancel ().

Exemple

L'exemple suivant montre l'utilisation du $mdBottomSheet service et aussi l'utilisation de la feuille de fond.

am_bottomsheet.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
	  
     <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('bottomSheetController', bottomSheetController);

         function bottomSheetController ($scope, $mdBottomSheet) {
            $scope.openBottomSheet = function() {
               $mdBottomSheet.show ({
                  template: '<md-bottom-sheet>Learn <b>Angular Material</b> @ TutorialsPoint.com!</md-bottom-sheet>'
               });
            };
         }  
      </script>      
   </head>
   
   <body ng-app = "firstApplication">
      <div ng-controller = "bottomSheetController as ctrl" layout = "column">
         <md-content class = "md-padding">
            <form ng-submit = "$event.preventDefault()">
               <md-button class = "md-raised md-primary" ng-click = "openBottomSheet()">
                  Open Bottom Sheet!
               </md-button>
            </form>
         </md-content>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-card, une directive angulaire, est une directive conteneur et est utilisée pour dessiner des cartes dans l'application angularjs. Le tableau suivant répertorie les directives angulaires et les classes utilisées dans md-card.

Sr. Non Directive / Classe et description
1

<md-card-header>

En-tête de la carte, contient l'avatar, le texte et l'image au carré.

2

<md-card-avatar>

Avatar de la carte.

3

md-user-avatar

Classe pour l'image de l'utilisateur.

4

<md-icon>

Directive d'icône.

5

<md-card-header-text>

Contient des éléments pour la description de la carte.

6

md-title

Classe pour le titre de la carte.

sept

md-subhead

Classe pour le sous-en-tête de la carte.

8

<img>

Image de la carte.

9

<md-card-title>

Titre du contenu de la carte.

dix

<md-card-title-text>

Conteneur de texte du titre de la carte.

11

md-headline

Classe pour le titre du contenu de la carte.

12

md-subhead

Classe pour le sous-en-tête du contenu de la carte.

13

<md-card-title-media>

Image carrée dans le titre.

14

md-media-sm

Classe pour petite image.

15

md-media-md

Classe pour l'image moyenne.

16

md-media-lg

Classe pour une grande image.

17

<md-card-content>

Contenu de la carte.

18

md-media-xl

Classe pour une image extra large.

19

<md-card-actions>

Actions de la carte.

20

<md-card-icon-actions>

Actions d'icône.

Exemple

L'exemple suivant montre l'utilisation de la directive md-card ainsi que l'utilisation des classes de cartes.

am_cards.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('cardController', cardController);

         function cardController ($scope) {            
         }  
      </script>      
   </head>
   
   <body ng-app = "firstApplication">  
      <md-card>
         <img ng-src = "/html5/images/html5-mini-logo.jpg" class = "md-card-image" alt = "Learn HTML5">
         <md-card-header>
            <md-card-avatar>
               <img class = "md-user-avatar" src = "/html5/images/html5-mini-logo.jpg">
            </md-card-avatar>
            
            <md-card-header-text>
               <span class = "md-title">HTML5</span>
               <span class = "md-subhead">Learn HTML5 @TutorialsPoint.com</span>
            </md-card-header-text>
         </md-card-header>
         
         <md-card-title>
            <md-card-title-text>
               <span class = "md-headline">HTML5</span>
            </md-card-title-text>
         </md-card-title>
         
         <md-card-actions layout = "row" layout-align = "start center">
            <md-button>Download</md-button>
            <md-button>Start</md-button>
            <md-card-icon-actions>
               <md-button class = "md-icon-button" aria-label = "icon">
                  <md-icon class = "material-icons">add</md-icon>
               </md-button>
            </md-card-icon-actions>
         </md-card-actions>
         
         <md-card-content>
            <p>HTML5 is the next major revision of the HTML standard superseding HTML 4.01,
            XHTML 1.0, and XHTML 1.1. HTML5 is a standard for structuring and presenting 
            content on the World Wide Web.</p>
            
            <p>HTML5 is a cooperation between the World Wide Web Consortium (W3C) and the
            Web Hypertext Application Technology Working Group (WHATWG).</p>
            
            </p>The new standard incorporates features like video playback and 
            drag-and-drop that have been previously dependent on third-party browser
            plug-ins such as Adobe Flash, Microsoft Silverlight, and Google Gears.</p>
         </md-card-content>
      </md-card>
   </body>
</html>

Résultat

Vérifiez le résultat.

Angular Material fournit une riche bibliothèque de widgets d'interface utilisateur. Cela permet aux utilisateurs d'avoir une capacité d'interaction avancée avec l'application.

Le tableau suivant répertorie quelques widgets importants avec leur description -

Sr. Non Widget et description
1 Boutons

le md-button, une directive angulaire, est une directive de bouton ayant des ondulations d'encre facultatives (et sont activées par défaut). Sihref ou ng-href est fourni, alors cette directive agit comme un élément d'ancrage.

2 CheckBoxes

le md-checkbox, une directive angulaire, est utilisée comme contrôle de case à cocher.

3 Contenu

le md-content, une directive angulaire, est un élément de conteneur et est utilisé pour le contenu défilable. lelayout-padding l'attribut peut être ajouté pour avoir un contenu complété.

4 Sélecteur de date

le md-datepicker, une directive angulaire, est un contrôle d'entrée pour sélectionner une date. Il prend également en charge ngMessages pour la validation des entrées.

5 Dialogues

le md-dialog, une directive angulaire, est un élément conteneur et est utilisé pour afficher une boîte de dialogue. Son élémentmd-dialog-content contient le contenu de la boîte de dialogue et le md-dialog-actions est responsable des actions de dialogue.

le mdDialog, un service angulaire, ouvre une boîte de dialogue sur l'application pour tenir les utilisateurs informés et les aider à prendre des décisions.

6 Diviseur

le md-divider, une directive angulaire, est un élément de règle et est utilisé pour afficher une règle fine et légère pour regrouper et diviser le contenu dans des listes et des mises en page.

sept liste

le md-list, une directive angulaire, est un composant conteneur qui contient md-list-iteméléments en tant qu'enfants. La directive md-list-item est un composant de conteneur pour les éléments de ligne du conteneur md-list. Classes CSSmd-2-line et md-3-line peut être ajouté à md-list-item pour augmenter la hauteur de la ligne avec respectivement 22px et 40px.

8 Menu

le md-menu, une directive angulaire, est un composant permettant d'afficher des options d'ajout dans le contexte de l'action effectuée. lemd-menua deux éléments enfants. Le premier élément est letrigger elementet est utilisé pour ouvrir le menu. Le deuxième élément est lemd-menu-contentpour représenter le contenu du menu lorsque le menu est ouvert. Le md-menu-content porte généralement les éléments de menu sous la forme md-menu-item.

9 Barre de menu

le md-menu-bar, est un composant conteneur destiné à contenir plusieurs menus. La barre de menus permet de créer un effet de menu fourni par le système d'exploitation.

dix Barres de progression

le md-progress-circular et md-progress-linear sont des directives de progression angulaire et sont utilisées pour afficher le message de chargement du contenu dans l'application.

11 Boutons radio

le md-radio-group et md-radio-buttonLes directives angulaires sont utilisées pour afficher les boutons radio dans l'application. Le md-radio-group est le conteneur de regroupement des éléments md-radio-button.

12 Sélectionne

le md-select, une directive angulaire est utilisée pour afficher la boîte de sélection, délimitée par ng-model.

13 Barres d'outils Fab

le md-fab-toolbar, une directive angulaire, est utilisée pour afficher une barre d'outils d'éléments ou de boutons pour un accès rapide aux actions courantes.

14 Curseurs

le md-slider, une directive angulaire est utilisée pour afficher un composant de plage. Il a deux modes -

  • normal- L'utilisateur peut glisser entre une large gamme de valeurs. Défaut.

  • discrete- L'utilisateur peut glisser entre les valeurs sélectionnées. Pour activer le mode discret, utilisez les attributs md-discrete et step.

15 Onglets

le md-tabs et md-tabLes directives angulaires sont utilisées pour afficher les onglets dans l'application. md-tabs est le conteneur de regroupement des éléments md-tab.

16 Barres d'outils

le md-toolbar, une directive angulaire est utilisée pour afficher une barre d'outils qui est normalement une zone au-dessus du contenu pour afficher le titre et les boutons appropriés.

17 Info-bulles

Le matériau angulaire fournit diverses méthodes spéciales pour afficher des infobulles discrètes aux utilisateurs. Le matériau angulaire fournit des moyens de leur attribuer des directions et la directive md-tooltip est utilisée pour afficher les info-bulles. Une info-bulle s'active chaque fois que l'utilisateur se concentre, survole ou touche le composant parent.

18 chips

le md-chips, une directive angulaire, est utilisé comme un composant spécial appelé puce et peut être utilisé pour représenter un petit ensemble d'informations, par exemple, un contact, des balises, etc. Un modèle personnalisé peut être utilisé pour rendre le contenu d'une puce. Ceci peut être réalisé en spécifiant un élément md-chip-template ayant le contenu personnalisé comme enfant de md-chips.

19 Puces de contact

le md-contact-chips, une directive angulaire, est un contrôle d'entrée construit sur des puces md et utilise le md-autocompleteélément. Le composant de puce de contact accepte une expression de requête qui renvoie une liste de contacts possibles. Un utilisateur peut en sélectionner un et l'ajouter à la liste des puces disponibles.

Directive de mise en page

La directive de mise en page sur un élément de conteneur est utilisée pour spécifier la direction de mise en page de ses enfants. Voici les valeurs attribuables pour la directive de mise en page -

  • row - Les articles sont disposés horizontalement avec max-height = 100% et max-width est la largeur des articles dans le conteneur.

  • column - Les articles sont disposés verticalement avec max-width = 100% et max-height est la hauteur des articles dans le conteneur.

Pour que la conception adaptative telle que la mise en page soit automatiquement modifiée en fonction de la taille de l'écran de l'appareil, les API de mise en page répertoriées dans le tableau suivant peuvent être utilisées pour définir la direction de la mise en page des appareils avec des largeurs de vue.

Sr. Non API et largeur de l'appareil lorsque le point d'arrêt remplace la valeur par défaut
1

layout

Définit la direction de mise en page par défaut à moins qu'elle ne soit remplacée par un autre point d'arrêt.

2

layout-xs

largeur <600px

3

layout-gt-xs

largeur> = 600px

4

layout-sm

600px <= largeur <960px

5

layout-gt-sm

largeur> = 960px

6

layout-md

960px <= largeur <1280px

sept

layout-gt-md

largeur> = 1280px

8

layout-lg

1280px <= largeur <1920px

9

layout-gt-lg

largeur> = 1920px

dix

layout-xl

largeur> = 1920px

Exemple

L'exemple suivant montre l'utilisation de la directive de mise en page ainsi que les utilisations de la mise en page.

am_layouts.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      <style>
         .box {         
            color:white;
            padding:10px;
            text-align:center;
            border-style: inset;
         }
         
         .green {
            background:green;
         }
         
         .blue {
            background:blue;
         }
      </style>
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('layoutController', layoutController);

         function layoutController ($scope) {            
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "layoutContainer" ng-controller = "layoutController as ctrl"
         style = "height:100px;" ng-cloak>
         <div layout = "row" layout-xs = "column">
            <div flex class = "green box">Row 1: Item 1</div>
            <div flex = "20" class = "blue box">Row 1: Item 2</div>
         </div>
         
         <div layout = "column" layout-xs = "column">
            <div flex = "33" class = "green box">Column 1: item 1</div>
            <div flex = "66" class = "blue box">Column 1: item 2</div>
         </div>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

Directive Flex

La directive flex sur un élément conteneur est utilisée pour personnaliser la taille et la position des éléments. Il définit la manière dont l'élément doit ajuster sa taille par rapport à son conteneur parent et aux autres éléments du conteneur. Voici les valeurs attribuables pour la directive flex -

  • multiples of 5 - 5, 10, 15 ... 100

  • 33 - 33%

  • 66 - 66%

Exemple

L'exemple suivant montre l'utilisation de la directive flex ainsi que les utilisations de flex.

am_flex.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <style>
         .box {         
            color:white;
            padding:10px;
            text-align:center;
            border-style: inset;
         }
         
         .green {
            background:green;
         }
         
         .blue {
            background:blue;
         }
      </style>
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('layoutController', layoutController);

         function layoutController ($scope) {            
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "layoutContainer" ng-controller = "layoutController as ctrl"
         layout = "row" style = "height:100px;" ng-cloak layout-wrap>
         <div flex = "30" class = "green box">
            [flex = "30"]
         </div>
         
         <div flex = "45" class = "blue box">
            [flex = "45"]
         </div>
         
         <div flex = "25" class = "green box">
            [flex = "25"]
         </div>
         
         <div flex = "33" class = "green box">
            [flex = "33"]
         </div>
         
         <div flex = "66" class = "blue box">
            [flex = "66"]
         </div>
         
         <div flex = "50" class = "blue box">
            [flex = "50"]
         </div>
         
         <div flex class = "green box">
            [flex]
         </div>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-input-container, une directive Angular, est un composant conteneur qui contient tout <input> ou <textarea>élément en tant qu'enfant. Il prend également en charge la gestion des erreurs à l'aide des directives standard ng-messages et anime les messages à l'aide des événements ngEnter / ngLeave ou des événements ngShow / ngHide.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs du md-input-container.

Sr. Non Paramètre et description
1

md-maxlength

Le nombre maximum de caractères autorisés dans cette entrée. Si cela est spécifié, un compteur de caractères sera affiché sous l'entrée. Le but de md-maxlength est d'afficher le texte du compteur de longueur maximale. Si vous ne voulez pas le texte du compteur et n'avez besoin que d'une validation "simple", vous pouvez utiliser les attributs "simples" ng-maxlength ou maxlength.

2

aria-label

Aria-label est nécessaire lorsqu'aucune étiquette n'est présente. Un message d'avertissement sera enregistré dans la console si une étiquette n'est pas présente.

3

placeholder

Une approche alternative à l'utilisation de aria-label lorsque l'étiquette n'est pas présente. Le texte de l'espace réservé est copié dans l'attribut aria-label.

4

md-no-autogrow

Lorsqu'elles sont présentes, les zones de texte ne se développeront pas automatiquement.

5

md-detect-hidden

Lorsqu'elles sont présentes, les zones de texte seront dimensionnées correctement lorsqu'elles sont révélées après avoir été masquées. Cette option est désactivée par défaut pour des raisons de performances, car elle garantit une redistribution à chaque cycle de résumé.

Exemple

L'exemple suivant montre l'utilisation de la directive md-input-container ainsi que les utilisations des entrées.

am_inputs.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      <style>
        
      </style>
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('inputController', inputController);

         function inputController ($scope) {
            $scope.project = {
               comments: 'Comments',    
            };
         }                 
      </script>     	  
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "inputContainer" class = "inputDemo"
         ng-controller = "inputController as ctrl" ng-cloak>
         <md-content layout-padding>
            <form name = "projectForm">
               
               <md-input-container class = "md-block">
                  <label>User Name</label>
                  <input required name = "userName" ng-model = "project.userName">
                  <div ng-messages = "projectForm.userName.$error">
                     <div ng-message = "required">This is required.</div>
                  </div>
               </md-input-container>
               
               <md-input-container class = "md-block">
                  <label>Email</label>
                  <input required type = "email" name = "userEmail"
                     ng-model = "project.userEmail"
                     minlength = "10" maxlength = "100" ng-pattern = "/^.+@.+\..+$/" />
                  <div ng-messages = "projectForm.userEmail.$error" role = "alert">
                     <div ng-message-exp = "['required', 'minlength', 'maxlength',
                        'pattern']">
                        Your email must be between 10 and 100 characters long and should
                        be a valid email address.
                     </div>
                  </div>
               </md-input-container>
               
               <md-input-container class = "md-block">
                  <label>Comments</label>
                  <input md-maxlength = "300" required name = "comments"
                     ng-model = "project.comments">
                  <div ng-messages = "projectForm.comments.$error">
                     <div ng-message = "required">This is required.</div>
                     <div ng-message = "md-maxlength">The comments has to be less
                        than 300 characters long.</div>
                  </div>
               </md-input-container>
               
            </form>
         </md-content>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-icon, une directive angulaire, est un composant permettant d'afficher des icônes vectorielles dans l'application. Il prend en charge les polices d'icônes et les icônes SVG, en plus d'utiliser les icônes de matériau Google.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-icon.

Sr. Non Paramètre et description
1

* md-font-icon

Il s'agit du nom de chaîne de l'icône CSS associée à la police, qui sera utilisée pour rendre l'icône. Nécessite que les polices et les styles CSS nommés soient préchargés.

2

* md-font-set

Il s'agit du nom de style CSS associé à la bibliothèque de polices, qui sera attribué comme classe pour la ligature police-icône. Cette valeur peut également être un alias utilisé pour rechercher le nom de classe; utilisez en interne $ mdIconProvider.fontSet (<alias>) pour déterminer le nom du style.

3

* md-svg-src

Il s'agit de l'URL (ou expression) de chaîne utilisée pour charger, mettre en cache et afficher un SVG externe.

4

* md-svg-icon

Il s'agit du nom de chaîne utilisé pour la recherche de l'icône dans le cache interne; des chaînes ou expressions interpolées peuvent également être utilisées. Des noms d'ensemble spécifiques peuvent être utilisés avec la syntaxe <nom d'ensemble>: <nom d'icône>. Pour utiliser des jeux d'icônes, les développeurs doivent pré-enregistrer les jeux à l'aide du service $ mdIconProvider.

5

aria-label

Cette icône d'étiquettes d'accessibilité. Si une chaîne vide est fournie, l'icône sera masquée de la couche d'accessibilité avec aria-hidden = "true". S'il n'y a pas d'étiquette aria sur l'icône ni d'étiquette sur l'élément parent, un avertissement sera enregistré dans la console.

6

alt

Cette icône d'étiquettes d'accessibilité. Si une chaîne vide est fournie, l'icône sera masquée de la couche d'accessibilité avec aria-hidden = "true". S'il n'y a pas d'alt sur l'icône ni d'étiquette sur l'élément parent, un avertissement sera enregistré dans la console.

Exemple

L'exemple suivant montre l'utilisation de la directive md-icons ainsi que les utilisations des icônes.

am_icons.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      <style>
         .iconDemo .glyph {
            border-bottom: 1px dotted #ccc;
            padding: 10px 0 20px;
            margin-bottom: 20px; 
         }
         
         .iconDemo .preview-glyphs {
            display: flex;
            flex-direction: row; 
         }
         
         .iconDemo .step {
            flex-grow: 1;
            line-height: 0.5; 
         }
         
         .iconDemo .material-icons.md-18 {
            font-size: 18px; 
         }
         
         .iconDemo .material-icons.md-24 {
            font-size: 24px; 
         }
         
         .iconDemo .material-icons.md-36 {
            font-size: 36px; 
         }
         
         .iconDemo .material-icons.md-48 {
            font-size: 48px; 
         }
         
         .iconDemo .material-icons.md-dark {
            color: rgba(0, 0, 0, 0.54); 
         }
         
         .iconDemo .material-icons.md-dark.md-inactive {
            color: rgba(0, 0, 0, 0.26); 
         }
         
         .iconDemo .material-icons.md-light {
            color: white; 
         }
         
         .iconDemo .material-icons.md-light.md-inactive {
            color: rgba(255, 255, 255, 0.3); 
         }
      </style>
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('iconController', iconController);

         function iconController ($scope) {
            var iconData = [
               {name: 'accessibility'  , color: "#777" },
               {name: 'question_answer', color: "rgb(89, 226, 168)" },
               {name: 'backup'         , color: "#A00" },
               {name: 'email'          , color: "#00A" }
            ];
            
            $scope.fonts = [].concat(iconData);            
            $scope.sizes = [
               {size:"md-18",padding:0},
               {size:"md-24",padding:2},
               {size:"md-36",padding:6},
               {size:"md-48",padding:10}
            ];
         }                 
      </script>     	  
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "iconContainer" class = "iconDemo"
         ng-controller = "iconController as ctrl" ng-cloak>
         <div class = "glyph" ng-repeat = "font in fonts" layout = "row">
            <div ng-repeat = "it in sizes" flex layout-align = "center center"
               style = "text-align: center;" layout = "column">
            <div flex></div>
               <div class = "preview-glyphs">
                  <md-icon ng-style = "{color: font.color}"
                     aria-label = "{{ font.name }}"
                     class = "material-icons step"
                     ng-class = "it.size">
                     {{ font.name }}
                  </md-icon>
               </div>
            </div>
         </div>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-grid-list, une directive angulaire, est un composant permettant de disposer du contenu pour différentes tailles d'écran. Une grille comporte 12 colonnes dans l'écran de taille de bureau, 8 dans l'écran de taille de tablette et 4 dans l'écran de taille de téléphone, où chaque taille a des marges et des gouttières prédéfinies. Les cellules sont disposées de manière séquentielle dans une ligne, dans l'ordre dans lequel elles sont définies.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-grid-list.

Sr. Non Paramètre et description
1

* md-cols

C'est pour le nombre de colonnes de la grille.

2

* md-row-height

Un des

  • CSS length - Rangées à hauteur fixe (par exemple 8px ou 1rem).

  • {width}:{height} - Rapport largeur / hauteur (par exemple md-row-height = "16: 9").

  • "fit" - La hauteur sera déterminée en subdivisant la hauteur disponible par le nombre de lignes.

3

md-gutter

La quantité d'espace entre les tuiles en unités CSS (1px par défaut).

4

md-on-layout

Expression à évaluer après mise en page. L'objet Event est disponible en tant que $ event et contient des informations sur les performances.

Exemple

L'exemple suivant montre l'utilisation du md-grid-list directive et aussi les utilisations de la grille.

am_grid.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('gridController', gridController);

         function gridController ($scope) {
            var COLORS = [
               '#ffebee', '#ffcdd2', '#ef9a9a', '#e57373', '#ef5350', '#f44336',
               '#e53935', '#d32f2f', '#c62828', '#b71c1c', '#ff8a80', '#ff5252',
               '#ff1744', '#d50000', '#f8bbd0', '#f48fb1', '#f06292', '#ec407a',
               '#e91e63', '#d81b60', '#c2185b', '#ad1457', '#880e4f', '#ff80ab',
               '#ff4081', '#f50057', '#c51162', '#e1bee7', '#ce93d8', '#ba68c8',
               '#ab47bc', '#9c27b0', '#8e24aa', '#7b1fa2', '#4a148c', '#ea80fc',
               '#e040fb', '#d500f9', '#aa00ff', '#ede7f6', '#d1c4e9', '#b39ddb',
               '#9575cd', '#7e57c2', '#673ab7', '#5e35b1', '#4527a0', '#311b92',
               '#b388ff', '#7c4dff', '#651fff', '#6200ea', '#c5cae9', '#9fa8da',
               '#7986cb', '#5c6bc0', '#3f51b5', '#3949ab', '#303f9f', '#283593',
               '#1a237e', '#8c9eff', '#536dfe', '#3d5afe', '#304ffe', '#e3f2fd',
               '#bbdefb', '#90caf9', '#64b5f6', '#42a5f5', '#2196f3', '#1e88e5',
               '#1976d2', '#1565c0', '#0d47a1', '#82b1ff', '#448aff', '#2979ff',
               '#2962ff', '#b3e5fc', '#81d4fa', '#4fc3f7', '#29b6f6', '#03a9f4',
               '#039be5', '#0288d1', '#0277bd', '#01579b', '#80d8ff', '#40c4ff',
               '#00b0ff', '#0091ea', '#e0f7fa', '#b2ebf2', '#80deea', '#4dd0e1',
               '#26c6da', '#00bcd4', '#00acc1', '#0097a7', '#00838f', '#006064',
               '#84ffff', '#18ffff', '#00e5ff', '#00b8d4', '#e0f2f1', '#b2dfdb',
               '#80cbc4', '#4db6ac', '#26a69a', '#009688', '#00897b', '#00796b',
               '#00695c', '#a7ffeb', '#64ffda', '#1de9b6', '#00bfa5', '#e8f5e9',
               '#c8e6c9', '#a5d6a7', '#81c784', '#66bb6a', '#4caf50', '#43a047',
               '#388e3c', '#2e7d32', '#1b5e20', '#b9f6ca', '#69f0ae', '#00e676',
               '#00c853', '#f1f8e9', '#dcedc8', '#c5e1a5', '#aed581', '#9ccc65',
               '#8bc34a', '#7cb342', '#689f38', '#558b2f', '#33691e', '#ccff90',
               '#b2ff59', '#76ff03', '#64dd17', '#f9fbe7', '#f0f4c3', '#e6ee9c',
               '#dce775', '#d4e157', '#cddc39', '#c0ca33', '#afb42b', '#9e9d24',
               '#827717', '#f4ff81', '#eeff41', '#c6ff00', '#aeea00', '#fffde7',
               '#fff9c4', '#fff59d', '#fff176', '#ffee58', '#ffeb3b', '#fdd835',
               '#fbc02d', '#f9a825', '#f57f17', '#ffff8d', '#ffff00', '#ffea00',
               '#ffd600', '#fff8e1', '#ffecb3', '#ffe082', '#ffd54f', '#ffca28',
               '#ffc107', '#ffb300', '#ffa000', '#ff8f00', '#ff6f00', '#ffe57f',
               '#ffd740', '#ffc400', '#ffab00', '#fff3e0', '#ffe0b2', '#ffcc80',
               '#ffb74d', '#ffa726', '#ff9800', '#fb8c00', '#f57c00', '#ef6c00',
               '#e65100', '#ffd180', '#ffab40', '#ff9100', '#ff6d00', '#fbe9e7',
               '#ffccbc', '#ffab91', '#ff8a65', '#ff7043', '#ff5722', '#f4511e',
               '#e64a19', '#d84315', '#bf360c', '#ff9e80', '#ff6e40', '#ff3d00',
               '#dd2c00', '#d7ccc8', '#bcaaa4', '#795548', '#d7ccc8', '#bcaaa4',
               '#8d6e63', '#eceff1', '#cfd8dc', '#b0bec5', '#90a4ae', '#78909c',
               '#607d8b', '#546e7a', '#cfd8dc', '#b0bec5', '#78909c'
            ];
            
            this.colorTiles = (function() {
               var tiles = [];
               for (var i = 0; i < 46; i++) {
                  tiles.push ({
                     color: randomColor(),
                     colspan: randomSpan(),
                     rowspan: randomSpan()
                  });
               }
               return tiles;
            })();
            
            function randomColor() {
               return COLORS[Math.floor(Math.random() * COLORS.length)];
            }
            
            function randomSpan() {
               var r = Math.random();
               if (r < 0.8) {
                  return 1;
               } else if (r < 0.9) {
                  return 2;
               } else {
                  return 3;
               }
            }      
         }                 
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "gridContainer" ng-controller = "gridController as ctrl" ng-cloak>
         <md-content layout-padding>
            <md-grid-list
               md-cols-gt-md = "12" md-cols-sm = "3" md-cols-md = "8"
               md-row-height-gt-md = "1:1" md-row-height = "4:3"
               md-gutter-gt-md = "16px" md-gutter-gt-sm = "8px" md-gutter = "4px">
               
               <md-grid-tile
                  ng-repeat = "tile in ctrl.colorTiles"
                  ng-style = "{
                     'background': tile.color
                  }"
                  md-colspan-gt-sm = "{{tile.colspan}}"
                  md-rowspan-gt-sm = "{{tile.rowspan}}">
               </md-grid-tile>
               
            </md-grid-list>
         </md-content>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

Redimensionnez l'écran pour voir l'effet.

le md-sidenav, une directive Angular est utilisée pour afficher un composant conteneur qui peut être affiché ou masqué par programme. Il glisse au-dessus de la région de contenu principale par défaut.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-sidenav

Sr. Non Paramètre et description
1

md-is-open

Un modèle lié à l'ouverture du sidenav.

2

md-component-id

componentId à utiliser avec le service $ mdSidenav.

3

md-is-locked-open

Lorsque cette expression prend la valeur true, le sidenav «se verrouille»: il tombe dans le flux du contenu au lieu d'apparaître dessus. Cela remplace l'attribut is-open. Le service $ mdMedia () est exposé à l'attribut is-lock-open, qui peut recevoir une requête multimédia ou l'un des préréglages sm, gt-sm, md, gt-md, lg ou gt-lg.

Examples -

<md-sidenav md-is-locked-open = "shouldLockOpen"></md-sidenav>
<md-sidenav md-is-locked-open = "$mdMedia('min-width: 1000px')"></mdsidenav>
<md-sidenav md-is-locked-open = "$mdMedia('sm')"></md-sidenav> <!--(locks open on small screens)-->

Exemple

L'exemple suivant montre l'utilisation de md-sidenav et aussi les utilisations du sidenav composant.

am_sidenav.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet" href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('sideNavController', sideNavController);

         function sideNavController ($scope, $mdSidenav) {
            $scope.openLeftMenu = function() {
               $mdSidenav('left').toggle();
            };
             
            $scope.openRightMenu = function() {
               $mdSidenav('right').toggle();
            };
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "sideNavContainer" ng-controller = "sideNavController as ctrl"
         layout = "row" ng-cloak>
         <md-sidenav md-component-id = "left" class = "md-sidenav-left">
            Welcome to TutorialsPoint.Com</md-sidenav>
         
         <md-content>           
            <md-button ng-click = "openLeftMenu()">Open Left Menu</md-button>
            <md-button ng-click = "openRightMenu()">Open Right Menu</md-button>
         </md-content>
         
         <md-sidenav md-component-id = "right" class = "md-sidenav-right">
            <md-button href = "http://google.com">Google</md-button>
         </md-sidenav>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-fab-speed-dial, une directive angulaire, est utilisée pour afficher une série d'éléments ou de boutons contextuels pour un accès rapide aux actions courantes.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-fab-speed-dial.

Sr. Non Paramètre et description
1

* md-direction

Cela détermine la direction dans laquelle la numérotation abrégée doit apparaître par rapport à l'élément déclencheur.

2

md-open

Cela permet de contrôler par programme si la numérotation abrégée est visible ou non.

Exemple

L'exemple suivant montre l'utilisation de la directive md-fab-speed-dial ainsi que les utilisations de la numérotation abrégée.

am_speeddial.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <style>
         .fabSpeedDial .text-capitalize {
            text-transform: capitalize; 
         }
         
         .fabSpeedDial .md-fab:hover, .fabSpeedDialdemoBasicUsage .md-fab.md-focused {
            background-color: #000 !important; 
         }
         
         .fabSpeedDial p.note {
            font-size: 1.2rem; 
         }
         
         .fabSpeedDial .lock-size {
            min-width: 300px;
            min-height: 300px;
            width: 300px;
            height: 300px;
            margin-left: auto;
            margin-right: auto; 
         } 
      </style>

      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('speedDialController', speedDialController);

         function speedDialController ($scope) {
            this.topDirections = ['left', 'up'];
            this.bottomDirections = ['down', 'right'];
            this.isOpen = false;
            this.availableModes = ['md-fling', 'md-scale'];
            this.selectedMode = 'md-fling';
            this.availableDirections = ['up', 'down', 'left', 'right'];
            this.selectedDirection = 'up';
         }                 
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div class = "fabSpeedDial" id = "speedDialContainer"
         ng-controller = "speedDialController as ctrl" layout = "row" ng-cloak>
         <md-content>
            <div class = "lock-size" layout = "row" layout-align = "center center">
               <md-fab-speed-dial md-open = "ctrl.isOpen"
                  md-direction = "{{ctrl.selectedDirection}}"
                  ng-class = "ctrl.selectedMode">
                  
                  <md-fab-trigger>
                     <md-button aria-label = "menu" class = "md-fab md-warn">
                        <md-icon class = "material-icons">menu</md-icon>
                     </md-button>
                  </md-fab-trigger>
                  
                  <md-fab-actions>
                     <md-button aria-label = "Add" class = "md-fab md-raised md-mini
                        md-accent">
                        <md-icon class = "material-icons" aria-label = "Add">
                           add</md-icon>
                     </md-button>
                     
                     <md-button aria-label = "Insert Link" class = "md-fab md-raised
                        md-mini md-accent">
                        <md-icon class = "material-icons" aria-label = "Insert Link">
                           insert_link</md-icon>
                     </md-button>
                     
                     <md-button aria-label = "Edit" class = "md-fab md-raised md-mini
                           md-accent">
                        <md-icon class = "material-icons" aria-label = "Edit">
                           mode_edit</md-icon>
                     </md-button>
                  </md-fab-actions>
               </md-fab-speed-dial>
            </div>

            <div layout = "row" layout-align = "space-around">
               <div layout = "column" layout-align = "start center">
                  <b>Direction</b>
                  <md-radio-group ng-model = "ctrl.selectedDirection">
                     <md-radio-button ng-repeat = "direction in ctrl.availableDirections"
                        ng-value = "direction" class = "text-capitalize">
                        {{direction}}
                     </md-radio-button>
                  </md-radio-group>
               </div>
               
               <div layout = "column" layout-align = "start center">
                  <b>Open/Closed</b>
                  <md-checkbox ng-model = "ctrl.isOpen">
                     Open
                  </md-checkbox>
               </div>
               
               <div layout = "column" layout-align = "start center">
                  <b>Animation Modes</b>
                  <md-radio-group ng-model = "ctrl.selectedMode">
                     <md-radio-button ng-repeat = "mode in ctrl.availableModes"
                        ng-value = "mode">
                        {{mode}}
                     </md-radio-button>
                  </md-radio-group>
               </div>
               
            </div>
         </md-content>	 
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-subheader, une directive angulaire, est utilisée pour afficher un sous-en-tête pour une section.

Exemple

L'exemple suivant montre l'utilisation de md-subheader ainsi que les utilisations du composant subheader.

am_subheaders.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('subheaderController', subheaderController);

         function subheaderController ($scope) {
            $scope.fruitNames = ['Apple', 'Banana', 'Orange'];
            $scope.vegNames = ['Carrot', 'Potato', 'Cabbage'];
            $scope.eateries = ['Milk', 'Bread'];
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "subheaderContainer" ng-controller = "subheaderController as ctrl"
         layout = "column" flex layout-fill ng-cloak>
         <md-toolbar md-scroll-shrink>
            <div class = "md-toolbar-tools">Items</div>
         </md-toolbar>
         
         <md-content style = "height: 600px;">
            <section>
               <md-subheader class = "md-primary">Fruits</md-subheader>
               <md-list layout-padding>
                  <md-list-item ng-repeat = "fruits in fruitNames">
                     <div>
                        <p>{{fruits}}</p>
                     </div>
                  </md-list-item>
               </md-list>
            </section>
               
            <section>
               <md-subheader class = "md-warn">Vegetables</md-subheader>
               <md-list layout-padding>
                  <md-list-item ng-repeat = "veg in vegNames">
                     <div>
                        <p>{{veg}}</p>
                     </div>
                  </md-list-item>
               </md-list>
            </section>
               
            <section>
               <md-subheader>Eateries</md-subheader>
               <md-list layout-padding>
                  <md-list-item ng-repeat = "eatery in eateries">
                     <div>
                        <p>{{eatery}}</p>
                     </div>
                  </md-list-item>
               </md-list>
            </section>
         </md-content>
         
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

La fonctionnalité Swipe est destinée aux appareils mobiles. Les directives suivantes sont utilisées pour gérer les balayages.

  • md-swipe-down, une directive Angular est utilisée pour spécifier un comportement personnalisé lorsqu'un élément est balayé vers le bas.

  • md-swipe-left, une directive Angular est utilisée pour spécifier un comportement personnalisé lorsqu'un élément est balayé vers la gauche.

  • md-swipe-right, une directive Angular est utilisée pour spécifier un comportement personnalisé lorsqu'un élément est balayé vers la droite.

  • md-swipe-up, une directive Angular est utilisée pour spécifier un comportement personnalisé lorsqu'un élément est balayé vers le haut.

Exemple

L'exemple suivant montre l'utilisation de md-swipe- * ainsi que les utilisations des composants de balayage.

am_swipes.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <style>
         .swipeContainer .demo-swipe {
            padding: 20px 10px; 			
         }
         
         .swipeContainer .no-select {
            -webkit-touch-callout: none;
            -webkit-user-select: none;
            -khtml-user-select: none;
            -moz-user-select: none;
            -ms-user-select: none;
            user-select: none; 
         }
      </style>
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('swipeController', swipeController);

         function swipeController ($scope) {
            $scope.onSwipeLeft = function(ev) {
               alert('Swiped Left!');
            };
             
            $scope.onSwipeRight = function(ev) {
               alert('Swiped Right!');
            };
             
            $scope.onSwipeUp = function(ev) {
               alert('Swiped Up!');
            };
             
            $scope.onSwipeDown = function(ev) {
               alert('Swiped Down!');
            };
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <md-card>
         <div id = "swipeContainer" ng-controller = "swipeController as ctrl"
            layout = "row" ng-cloak>
            <div flex>
               <div class = "demo-swipe" md-swipe-left = "onSwipeLeft()">
                  <span class = "no-select">Swipe me to the left</span>
                  <md-icon md-font-icon = "android" aria-label = "android"></md-icon>
               </div>
               
               <md-divider></md-divider>
               <div class = "demo-swipe" md-swipe-right = "onSwipeRight()">
                  <span class = "no-select">Swipe me to the right</span>
               </div>
            </div>

            <md-divider></md-divider>
            <div flex layout = "row">
               <div flex layout = "row" layout-align = "center center"
                  class = "demo-swipe" md-swipe-up = "onSwipeUp()">
                  <span class = "no-select">Swipe me up</span>
               </div>
               
               <md-divider></md-divider>
               <div flex layout = "row" layout-align = "center center"
                  class = "demo-swipe" md-swipe-down = "onSwipeDown()">
                  <span class = "no-select">Swipe me down</span>
               </div>
            </div>
            
         </div>
      </md-card>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-switch, une directive angulaire, est utilisée pour afficher un commutateur.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-switch.

Sr. Non Paramètre et description
1

* ng-model

Expression angulaire attribuable à laquelle lier les données.

2

name

Nom de propriété du formulaire sous lequel le contrôle est publié.

3

ng-true-value

Valeur à laquelle l'expression doit être définie lorsqu'elle est sélectionnée.

4

ng-false-value

Valeur à laquelle l'expression doit être définie lorsqu'elle n'est pas sélectionnée.

5

ng-change

Expression angulaire à exécuter lorsque l'entrée change en raison de l'interaction de l'utilisateur avec l'élément d'entrée.

6

ng-disabled

En / Désactiver en fonction de l'expression.

sept

md-no-ink

L'utilisation de l'attribut indique l'utilisation d'effets d'encre ondulée.

8

aria-label

Cela publie le libellé du bouton utilisé par les lecteurs d'écran pour l'accessibilité. C'est par défaut le texte du commutateur.

Exemple

L'exemple suivant montre l'utilisation de md-swipe- * ainsi que les utilisations des composants de balayage.

am_switches.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('switchController', switchController);

         function switchController ($scope) {
            $scope.data = {
               switch1: true,
               switch2: false,
               switch3: false,
               switch4: true,
               switch5: true,
               switch6: false
            };
               
            $scope.message = 'false';
            $scope.onChange = function(state) {
               $scope.message = state;
            };
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "switchContainer" ng-controller = "switchController as ctrl"
         layout = "column" ng-cloak>
         <md-switch ng-model = "data.switch1" aria-label = "Switch 1">
            Switch 1: {{ data.switch1 }}
         </md-switch>
         
         <md-switch ng-model = "data.switch2" aria-label = "Switch 2"
            ng-true-value = "'true'" ng-false-value = "'false'" class = "md-warn">
            Switch 2 (md-warn): {{ data.switch2 }}
         </md-switch>
         
         <md-switch ng-disabled = "true" aria-label = "Disabled switch"
            ng-model = "disabledModel">
            Switch 3 (Disabled)
         </md-switch>
         
         <md-switch ng-disabled = "true" aria-label = "Disabled active switch"
            ng-model = "data.switch4">
            Switch 4 (Disabled, Active)
         </md-switch>
         
         <md-switch class = "md-primary" md-no-ink aria-label = "Switch No Ink"
            ng-model = "data.switch5">
            Switch 5 (md-primary): No Ink
         </md-switch>
         
         <md-switch ng-model = "data.switch6" aria-label = "Switch 6"
            ng-change = "onChange(data.switch6)">
            Switch 6 : {{ message }}
         </md-switch>    
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

Les composants de matériau angulaire utilisent les classes de groupe d'intention telles que md-primary, md-accent, md-warn et des classes supplémentaires pour les différences de couleur telles que md-hue-1, md-hue-2 ou md-hue-3. Les composants suivants prennent en charge l'utilisation des classes mentionnées ci-dessus.

  • md-button
  • md-checkbox
  • md-progress-circular
  • md-progress-linear
  • md-radio-button
  • md-slider
  • md-switch
  • md-tabs
  • md-text-float
  • md-toolbar

Les thèmes peuvent être configurés à l'aide de $ mdThemingProvider lors de la configuration de l'application. Les propriétés suivantes peuvent être utilisées pour attribuer différentes palettes de couleurs.

  • primaryPalette
  • accentPalette
  • warnPalette
  • backgroundPalette

Exemple

L'exemple suivant montre l'utilisation de thèmes dans l'application Angular JS.

am_themes.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('themeController', themeController)
            .config(function($mdThemingProvider) {
               $mdThemingProvider.theme('customTheme') 
               .primaryPalette('grey')
               .accentPalette('orange')
               .warnPalette('red');
            });

         function themeController ($scope) {            
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "themeContainer" ng-controller = "themeController as ctrl" ng-cloak>
         <md-toolbar class = "md-primary">
            <div class = "md-toolbar-tools">
               <h2 class = "md-flex">Default Theme</h2>
            </div>
         </md-toolbar>
         <hr/>
         
         <md-card>         
            <md-card-content layout = "column"> 
               <md-toolbar class = "md-primary">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-primary style</h2>
                  </div>
               </md-toolbar>
                  
               <md-toolbar class = "md-primary md-hue-1">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-primary md-hue-1 style</h2>
                  </div>
               </md-toolbar>
               
               <md-toolbar class = "md-primary md-hue-2">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-primary md-hue-2 style</h2>
                  </div></md-toolbar>
                  
               <md-toolbar class = "md-accent">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-accent style</h2>
                  </div>
               </md-toolbar>
               
               <md-toolbar class = "md-accent md-hue-1">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-accent md-hue-1 style</h2>
                  </div>
               </md-toolbar>
               
               <md-toolbar class = "md-accent md-hue-2">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-accent md-hue-2 style</h2>
                  </div>
               </md-toolbar>
               
               <md-toolbar class = "md-warn">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-warn style</h2>
                  </div>
               </md-toolbar>
               
               <md-toolbar class = "md-warn md-hue-1">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-warn md-hue-1 style</h2>
                  </div>
               </md-toolbar>
               
               <md-toolbar class = "md-warn md-hue-2">
                  <div class = "md-toolbar-tools">
                     <h2 class = "md-flex">Using md-warn md-hue-2 style</h2>
                  </div>
               </md-toolbar>              
            </md-card-content>
         </md-card>
         
         <div md-theme = "customTheme">
            <md-toolbar class = "md-primary">
               <div class = "md-toolbar-tools">
                  <h2 class = "md-flex">Custom Theme</h2>
               </div>
            </md-toolbar>
            <hr/>
            
            <md-card>         
               <md-card-content layout = "column"> 
                  <md-toolbar class = "md-primary">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-primary style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-primary md-hue-1">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-primary md-hue-1 style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-primary md-hue-2">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-primary md-hue-2 style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-accent">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-accent style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-accent md-hue-1">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-accent md-hue-1 style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-accent md-hue-2">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-accent md-hue-2 style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-warn">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-warn style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-warn md-hue-1">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-warn md-hue-1 style</h2>
                     </div>
                  </md-toolbar>
                  
                  <md-toolbar class = "md-warn md-hue-2">
                     <div class = "md-toolbar-tools">
                        <h2 class = "md-flex">Using md-warn md-hue-2 style</h2>
                     </div>
                  </md-toolbar>              
               </md-card-content>
            </md-card>
            
         </div>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

Le matériau angulaire fournit diverses méthodes spéciales pour afficher des alertes discrètes aux utilisateurs. Il leur fournit également un terme toast. Le service $ mdToast est utilisé pour afficher les toasts.

Exemple

L'exemple suivant montre l'utilisation de toasts.

am_toasts.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('toastController', toastController);

         function toastController ($scope, $mdToast, $document) { 
            $scope.showToast1 = function() {
               $mdToast.show (
                  $mdToast.simple()
                  .textContent('Hello World!')                       
                  .hideDelay(3000)
               );
            };

            $scope.showToast2 = function() {
               var toast = $mdToast.simple()
                  .textContent('Hello World!')
                  .action('OK')
                  .highlightAction(false);                     
               
               $mdToast.show(toast).then(function(response) {
                  if ( response == 'ok' ) {
                     alert('You clicked \'OK\'.');
                  }
               });			   
            }
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div id = "toastContainer" ng-controller = "toastController as ctrl"
         layout = "row" ng-cloak>
         <md-button ng-click = "showToast1()">Show Simple Alert</md-button>
         <md-button ng-click = "showToast2()">Show Alert with callback</md-button>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

Angular Material fournit diverses classes CSS de typographie qui peuvent être utilisées pour créer une cohérence visuelle dans l'application Angular JS.

Le tableau suivant répertorie les différentes classes avec leur description.

Sr. Non Nom et description de la classe
1

md-display-1

Affiche le texte avec Regular 34px.

2

md-display-2

Affiche le texte avec Regular 45px.

3

md-display-3

Affiche le texte avec Regular 56px.

4

md-display-4

Affiche le texte avec Light 112px.

5

md-headline

Affiche le texte avec Regular 24px.

6

md-title

Affiche le texte avec Medium 20px.

sept

md-subhead

Affiche le texte avec Regular 16px.

8

md-body-1

Affiche le texte avec Regular 14px.

9

md-body-2

Affiche le texte avec Medium 14px.

dix

md-button

Affiche le bouton avec Medium 14px.

11

md-caption

Affiche le texte avec Regular 12px.

Exemple

L'exemple suivant montre l'utilisation de classes CSS de typographie.

am_typography.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('typographyController', typographyController);
           
         function typographyController ($scope) {               
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div class = "frameContainer" ng-controller = "typographyController as ctrl"
         layout = "column" layout-padding layout-wrap layout-fill
         style = "padding-bottom: 32px;" ng-cloak>
         <p class = "md-display-4">.md-display-4</p>
         <p class = "md-display-3">.md-display-3</p>
         <p class = "md-display-2">.md-display-2</p>
         <p class = "md-display-1">.md-display-1</p>
         <p class = "md-headline">.md-headline</p>
         <p class = "md-title">.md-title</p>
         <p class = "md-subhead">.md-subhead</p>
         <p class = "md-body-1">.md-body-1</p>
         <p class = "md-body-2">.md-body-2</p>
         <md-button>.md-button</md-button>
         <p class = "md-caption">.md-caption</p>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

le md-virtual-repeat-container est le conteneur de défilement du composant md-virtual-repeat.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-virtual-repeat-container.

Sr. Non Paramètre et description
1

md-top-index

Lie l'index de l'élément qui se trouve en haut du conteneur de défilement à $ scope. Il peut à la fois lire et définir la position de défilement.

2

md-orient-horizontal

Détermine si le conteneur doit défiler horizontalement (par défaut, orientation et défilement vertical).

3

md-auto-shrink

Lorsqu'il est présent, le conteneur se rétrécit pour s'adapter au nombre d'articles lorsque ce nombre est inférieur à sa taille d'origine.

4

md-auto-shrink-min

Nombre minimum d'éléments auxquels md-auto-shrink sera réduit (par défaut: 0).

répétition virtuelle md

La répétition virtuelle est un substitut à ng-repeat pour ne rendre que suffisamment d'éléments html pour remplir le conteneur et les réutiliser lorsque l'utilisateur fait défiler.

Les attributs

Le tableau suivant répertorie les paramètres et la description des différents attributs de md-virtual-repeat.

Sr. Non Paramètre et description
1

md-item-size

La hauteur ou la largeur des éléments répétés (qui doivent être identiques pour chaque élément). Ceci est facultatif. Cela tente de lire la taille du dom s'il manque, mais suppose toujours que tous les nœuds répétés ont la même hauteur ou largeur.

2

md-extra-name

Évalue un nom supplémentaire auquel l'élément itéré actuel peut être attribué sur la portée répétée (nécessaire pour une utilisation dans md-autocomplete).

3

md-on-demand

Lorsqu'il est présent, traite le md-virtual-repeat comme un objet qui peut récupérer des lignes plutôt qu'un tableau.Cet objet doit implémenter l'interface suivante avec deux (2) méthodes -

  • getItemAtIndex - function (index) [object] - L'élément à cet index ou nul s'il n'est pas encore chargé (il devrait commencer à télécharger l'élément dans ce cas).

  • getLength- function () [number] - La longueur des données à laquelle le conteneur du répéteur doit être dimensionné. Idéalement, lorsque le décompte est connu, cette méthode doit le renvoyer. Sinon, retournez un nombre plus élevé que les éléments actuellement chargés pour produire un comportement de défilement infini.

Exemple

L'exemple suivant montre l'utilisation de la répétition virtuelle.

am_virtualrepeat.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <style>
         .vrepeatContainer #horizontal-container {
            height: 100px;
            width: 830px; 
         }

         .vrepeatContainer #vertical-container {
            height: 292px;
            width: 400px; 
         }

         .vrepeatContainer .repeated-item-horizontal {
            border-right: 1px solid #ddd;
            box-sizing: border-box;
            display: inline-block;
            height: 84px;
            padding-top: 35px;
            text-align: center;
            width: 50px; 
         }

         .vrepeatContainer .repeated-item-vertical {
            border-bottom: 1px solid #ddd;
            box-sizing: border-box;
            height: 40px;
            padding-top: 10px;
         }

         .vrepeatContainer md-content {
            margin: 16px; 
         }
         
         .vrepeatContainer md-virtual-repeat-container {
            border: solid 1px grey; 
         }	  
      </style>
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('vrepeatController', vrepeatController);
           
         function vrepeatController ($scope) { 
            this.items = [];
            for (var i = 0; i < 1000; i++) {
               this.items.push(i);
            }
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div class = "vrepeatContainer" ng-controller = "vrepeatController as ctrl"
         ng-cloak>
         <md-content layout = "column">
            <h2>Horizontal Repeat</h2>
            <md-virtual-repeat-container id = "horizontal-container" md-orient-horizontal>
               <div md-virtual-repeat = "item in ctrl.items"
                  class = "repeated-item-horizontal" flex>
                  {{item}}
               </div>
            </md-virtual-repeat-container>
            
            <h2>Vertical Repeat</h2>
            <md-virtual-repeat-container id = "vertical-container">
               <div md-virtual-repeat = "item in ctrl.items"
                  class = "repeated-item-vertical" flex>
                  {{item}}
               </div>
            </md-virtual-repeat-container>
            
         </md-content>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.

Le matériau angulaire a plusieurs classes spéciales pour afficher les conteneurs sous forme de cartes de type papier avec une ombre.

Le tableau suivant répertorie les différentes classes avec leur description.

Sr. Non Nom et description de la classe
1

md-whiteframe-1dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 1 px. Ajoute zdepth de 1.

2

md-whiteframe-2dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 2 pixels. Ajoute zdepth de 2.

3

md-whiteframe-3dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 3 pixels. Ajoute une profondeur de 3.

4

md-whiteframe-4dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 4 pixels. Ajoute zdepth de 4.

5

md-whiteframe-5dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 5 pixels. Ajoute zdepth de 5.

6

md-whiteframe-6dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 6 pixels. Ajoute zdepth de 6.

sept

md-whiteframe-7dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 7 pixels. Ajoute zdepth de 7.

8

md-whiteframe-8dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 8 pixels. Ajoute zdepth de 8.

9

md-whiteframe-9dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 9 pixels. Ajoute une profondeur de 9.

dix

md-whiteframe-10dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 10 pixels. Ajoute une profondeur z de 10.

11

md-whiteframe-11dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 11px. Ajoute une profondeur z de 11.

12

md-whiteframe-12dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 12 pixels. Ajoute une profondeur z de 12.

13

md-whiteframe-13dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 13 pixels. Ajoute une profondeur z de 13.

14

md-whiteframe-14dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 14 pixels. Ajoute une profondeur z de 14.

15

md-whiteframe-15dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 15 pixels. Ajoute une profondeur z de 15.

16

md-whiteframe-16dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 16 pixels. Ajoute une profondeur z de 16.

17

md-whiteframe-17dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 17 pixels. Ajoute une profondeur z de 17.

18

md-whiteframe-18dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 18 pixels. Ajoute une profondeur z de 18.

19

md-whiteframe-19dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 19 pixels. Ajoute une profondeur z de 19.

20

md-whiteframe-20dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 20 pixels. Ajoute une profondeur z de 20.

21

md-whiteframe-21dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 21 px. Ajoute une profondeur z de 21.

22

md-whiteframe-22dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 22 pixels. Ajoute une profondeur z de 22.

23

md-whiteframe-23dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 23 px. Ajoute une profondeur z de 23.

24

md-whiteframe-24dp

Cela met en forme un conteneur pour tout contenu HTML avec une ombre bordée de 24 pixels. Ajoute une profondeur z de 24.

Exemple

L'exemple suivant montre l'utilisation de classes d'ombre.

am_whiteframes.htm

<html lang = "en">
   <head>
      <link rel = "stylesheet"
         href = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.css">
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-animate.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-aria.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-messages.min.js"></script>
      <script src = "https://ajax.googleapis.com/ajax/libs/angular_material/1.0.0/angular-material.min.js"></script>
      <link rel = "stylesheet" href = "https://fonts.googleapis.com/icon?family=Material+Icons">
      
      <style>
         .frameContainer md-whiteframe {
            background: #fff;
            margin: 30px;
            height: 100px; 
         }
      </style>
      
      <script language = "javascript">
         angular
            .module('firstApplication', ['ngMaterial'])
            .controller('frameController', frameController);
           
         function frameController ($scope) {               
         }	  
      </script>      
   </head>
   
   <body ng-app = "firstApplication"> 
      <div class = "frameContainer" ng-controller = "frameController as ctrl"
         layout = "row" layout-padding layout-wrap layout-fill
         style = "padding-bottom: 32px;" ng-cloak>
         <md-whiteframe class = "md-whiteframe-1dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-1dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-2dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-2dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-3dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-3dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-10dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-10dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-15dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-15dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-20dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-20dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-22dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-22dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-23dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-23dp</span>
         </md-whiteframe>
         
         <md-whiteframe class = "md-whiteframe-24dp" flex-sm = "45" flex-gt-sm = "35"
            flex-gt-md = "25" layout layout-align = "center center">
            <span>.md-whiteframe-24dp</span>
         </md-whiteframe>
      </div>
   </body>
</html>

Résultat

Vérifiez le résultat.