Ionic - Popover Javascript

C'est une vue qui apparaîtra au-dessus de la vue normale.

Utilisation de Popover

Un Popover peut être créé en utilisant ion-popover-viewélément. Cet élément doit être ajouté au modèle HTML et au$ionicPopover le service doit être injecté dans le contrôleur.

Il existe trois façons d'ajouter un popover. Le premier est lefromTemplateméthode, qui permet d'utiliser le modèle en ligne. La deuxième et la troisième façon d'ajouter un popover consiste à utiliser lefromTemplateUrl méthode.

Laissez-nous comprendre le fromtemplate méthode comme expliqué ci-dessous.

Code de contrôleur pour la méthode Fromtemplate

.controller('DashCtrl', function($scope, $ionicLoading, $ionicPopover) {
   // .fromTemplate() method
   var template = '<ion-popover-view>' + '<ion-header-bar>' +
      '<h1 class = "title">Popover Title</h1>' +
      '</ion-header-bar>'+ '<ion-content>' +
      'Popover Content!' + '</ion-content>' + '</ion-popover-view>';

   $scope.popover = $ionicPopover.fromTemplate(template, {
      scope: $scope
   });

   $scope.openPopover = function($event) {
      $scope.popover.show($event);
   };

   $scope.closePopover = function() {
      $scope.popover.hide();
   };

   //Cleanup the popover when we're done with it!
   $scope.$on('$destroy', function() {
      $scope.popover.remove();
   });

   // Execute action on hide popover
   $scope.$on('popover.hidden', function() {
      // Execute action
   });

   // Execute action on remove popover
   $scope.$on('popover.removed', function() {
      // Execute action
   });
})

Comme indiqué ci-dessus, la deuxième et la troisième façon d'ajouter un popover consiste à utiliser fromTemplateUrlméthode. Le code du contrôleur sera le même dans les deux sens sauf pour lefromTemplateUrl valeur.

Si le HTML est ajouté à un modèle existant, l'URL sera le popover.html. Si nous voulons placer le HTML dans le dossier des modèles, l'URL deviendratemplates/popover.html.

Les deux exemples ont été expliqués ci-dessous.

Code de contrôleur pour fromTemplateUrl

.controller('MyCtrl', function($scope, $ionicPopover) {

   $ionicPopover.fromTemplateUrl('popover.html', {
      scope: $scope
   }).then(function(popover) {
      $scope.popover = popover;
   });

   $scope.openPopover = function($event) {
      $scope.popover.show($event);
   };

   $scope.closePopover = function() {
      $scope.popover.hide();
   };

   //Cleanup the popover when we're done with it!
   $scope.$on('$destroy', function() {
      $scope.popover.remove();
   });

   // Execute action on hide popover
   $scope.$on('popover.hidden', function() {
      // Execute action
   });

   // Execute action on remove popover
   $scope.$on('popover.removed', function() {
      // Execute action
   });
})

Maintenant, nous allons ajouter le script avec modèle au fichier HTML, que nous utilisons pour appeler la fonction popover.

Code HTML du fichier HTML existant

<script id = "popover.html" type = "text/ng-template">
   <ion-popover-view>
	
      <ion-header-bar>
         <h1 class = "title">Popover Title</h1>
      </ion-header-bar>
		
      <ion-content>
         Popover Content!
      </ion-content>
		
   </ion-popover-view>
</script>

Si nous voulons créer un fichier HTML en tant que fichier séparé, nous pouvons créer un nouveau fichier HTML dans le templates dossier et utilisez le même code que celui que nous avons utilisé dans l'exemple mentionné ci-dessus sans le script Mots clés.

Le fichier HTML nouvellement créé est le suivant.

<ion-popover-view>
   <ion-header-bar>
      <h1 class = "title">Popover Title</h1>
   </ion-header-bar>
	
   <ion-content>
      Popover Content!
   </ion-content>
</ion-popover-view>

La dernière chose dont nous avons besoin est de créer un bouton sur lequel vous cliquerez pour afficher le popover.

<button class = "button" ng-click = "openPopover($event)">Add Popover</button>

Quelle que soit la manière dont nous choisissons parmi les exemples ci-dessus, la sortie sera toujours la même.

Le tableau suivant montre les $ionicPopover méthodes qui peuvent être utilisées.

Méthode Option Type Détail
initialiser (options) scope, focusFirst, toile de fondClickToClose, hardwareBackButtonClose objet, booléen, booléen, booléen Scopeest utilisé pour transmettre la portée personnalisée au popover. La valeur par défaut est $ rootScope.focusFirstInput est utilisé pour mettre au point automatiquement la première entrée du popover. backdropClickToClose est utilisé pour fermer le popover lorsque vous cliquez sur le fond. hardwareBackButtonClose est utilisé pour fermer le popover lorsque le bouton de retour matériel est enfoncé.
show ($ événement) $ événement promettre Résolu lorsque le popover est terminé.
cacher() / promettre Résolu lorsque le popover a fini de se cacher.
retirer() / promettre Résolu lorsque la suppression du popover est terminée.
est montré() / Booléen Renvoie true si le popover est affiché ou false si ce n'est pas le cas.