Ionic - Menu latéral JavaScript

Le menu latéral est l'un des composants ioniques les plus utilisés. Le menu latéral peut être ouvert en faisant glisser vers la gauche ou vers la droite ou en déclenchant le bouton créé à cet effet.

Utilisation du menu latéral

Le premier élément dont nous avons besoin est ion-side-menus. Cet élément est utilisé pour connecter le menu latéral avec tous les écrans qui l'utiliseront. leion-side-menu-content élément est l'endroit où le contenu sera placé et le ion-side-menu élément est l'endroit où nous pouvons mettre un sidedirectif. Nous ajouterons le menu latéral auindex.html et placez le ion-nav-viewà l'intérieur du contenu du menu latéral. De cette façon, le menu latéral peut être utilisé dans toute l'application.

index.html

<ion-side-menus>

   <ion-side-menu>side = "left">
      <h1>SIde Menu</h1>
   </ion-side-menu>

   <ion-side-menu-content>
      <ion-nav-view>
      </ion-nav-view>
   </ion-side-menu-content>

</ion-side-menus>

Maintenant, nous allons créer un bouton with menu-toggle = "left"directif. Ce bouton sera généralement placé dans la barre d'en-tête des applications, mais nous l'ajouterons dans notre fichier modèle pour une meilleure compréhension.

Lorsque vous appuyez sur le bouton ou lorsque nous glissons vers la droite, le menu latéral s'ouvre. Vous pouvez également définir lemenu-close directive, si vous souhaitez avoir un seul bouton pour fermer le menu latéral, mais nous utiliserons le bouton bascule pour cela.

Modèle HTML

<button menu-toggle = "left" class = "button button-icon icon ion-navicon"></button>

Le code ci-dessus produira l'écran suivant -

Vous pouvez ajouter des attributs supplémentaires au ion-side-menusélément. leenable-menu-with-back-viewspeut être défini sur false pour désactiver le menu latéral, lorsque le bouton de retour est affiché. Cela masquera également lemenu-togglebouton de l'en-tête. L'autre attribut estdelegate-handle, qui sera utilisé pour la connexion avec $ionicSideMenuDelegate.

le ion-side-menu-contentL'élément peut utiliser son propre attribut. Quand ledrag-contentL'attribut est défini sur false, cela désactivera la possibilité d'ouvrir le menu latéral en faisant glisser l'écran de contenu. leedge-drag-thresholdL'attribut a une valeur par défaut de 25. Cela signifie que le balayage n'est autorisé qu'à 25 pixels des bords gauche et droit de l'écran. Nous pouvons modifier cette valeur numérique ou la définir surfalse pour activer le balayage sur tout l'écran ou true pour le désactiver.

le ion-side-menu peut utiliser le sideattribut que nous avons montré dans l'exemple ci-dessus. Il déterminera si le menu doit apparaître du côté gauche ou du côté droit. le‘is-enabled’ l'attribut avec une valeur fausse désactivera le menu latéral, et le widthLa valeur d'attribut est un nombre qui représente la largeur du menu latéral. La valeur par défaut est 275.

Délégué du menu latéral

le $ionicSideMenuDelegateest un service utilisé pour contrôler tous les menus latéraux de l'application. Nous vous montrerons comment l'utiliser, puis nous passerons en revue toutes les options disponibles. Comme tous les services Ionic, nous devons l'ajouter en tant que dépendance à notre contrôleur, puis l'utiliser dans la portée du contrôleur. Maintenant, lorsque nous cliquons sur le bouton, tous les menus latéraux s'ouvriront.

Code du contrôleur

.controller('MyCtrl', function($scope, $ionicSideMenuDelegate) {
   $scope.toggleLeftSideMenu = function() {
      $ionicSideMenuDelegate.toggleLeft();
   };
})

Code HTML

<button class = "button button-icon icon ion-navicon" ng-click = "toggleLeft()"></button>

Le tableau suivant montre les $ionicScrollDelegate méthodes.

Déléguer les méthodes

Méthode Paramètres Type Détails
toggleLeft (paramètre) est ouvert Booléen Utilisé pour ouvrir ou fermer le menu latéral.
toggleRight (paramètre) est ouvert Booléen Utilisé pour ouvrir ou fermer le menu latéral.
getOpenRatio () / / Renvoie le rapport de la partie ouverte sur la largeur du menu. Si la moitié du menu est ouverte depuis la gauche, la ration sera de 0,5. Si le menu latéral est fermé, il retournera 0. Si la moitié du menu est ouverte depuis le côté droit, il retournera -0,5.
est ouvert() / Booléen Renvoie true si le menu latéral est ouvert, false s'il est fermé.
isOpenLeft () / Booléen Renvoie true si le menu de gauche est ouvert, false s'il est fermé.
isOpenRight () / Booléen Renvoie true si le menu de droite est ouvert, false s'il est fermé.
getScrollPosition () / / Renvoie un objet avec deux nombres comme propriétés: left et right. Ces nombres représentent la distance parcourue par l'utilisateur à partir de la gauche et du haut respectivement.
canDragContent (paramètre1) canDrag Booléen Si le contenu peut être déplacé pour ouvrir le menu latéral.
edgeDragThreshold (paramètre1) valeur Booléen | nombre Si la valeur est true, le menu latéral peut être ouvert en faisant glisser 25px depuis les bords de l'écran. S'il est faux, le glissement est désactivé. Nous pouvons définir n'importe quel nombre qui représentera la valeur du pixel à partir du bord gauche et droit de l'écran.
$ getByHandle (paramètre1) manipuler chaîne Utilisé pour connecter des méthodes à la vue particulière du menu latéral avec la même poignée. $ionicSideMenuDelegate. $getByHandle('my-handle').toggleLeft();