Ionic - Défilement JavaScript

L'élément utilisé pour la manipulation du défilement dans les applications ioniques est appelé ion-scroll.

Utilisation du défilement

Les extraits de code suivants créeront des conteneurs à défilement et ajusteront les modèles de défilement. Tout d'abord, nous allons créer notre élément HTML et y ajouter des propriétés. Nous ajouterons →direction = "xy"pour permettre le défilement de tous les côtés. Nous définirons également la largeur et la hauteur de l'élément scroll.

Code HTML

<ion-scroll zooming = "true" direction = "xy" style = "width: 320px; height: 500px">
   <div class = "scroll-container"></div>
</ion-scroll>

Ensuite, nous ajouterons l'image de notre carte du monde à div élément, que nous avons créé à l'intérieur du ion-scroll et définissez sa largeur et sa hauteur.

Code CSS

.scroll-container {
   width: 2600px;
   height: 1000px;
   background: url('../img/world-map.png') no-repeat
}

Lorsque nous exécutons notre application, nous pouvons faire défiler la carte dans toutes les directions. L'exemple suivant montre la partie Amérique du Nord de la carte.

Nous pouvons faire défiler cette carte jusqu'à n'importe quelle partie que nous voulons. Faisons défiler pour montrer l'Asie.

Il existe d'autres attributs qui peuvent être appliqués au ion-scroll. Vous pouvez les vérifier dans le tableau suivant.

Attributs de défilement

Attribut Type Détails
direction chaîne Directions possibles du parchemin. La valeur par défaut esty
délégué-handle chaîne Utilisé pour l'identification de défilement avec $ionicScrollDelegate.
verrouillage booléen Utilisé pour verrouiller le défilement dans une direction à la fois. La valeur par défaut est true.
pagination booléen Utilisé pour déterminer si la pagination sera utilisée avec scroll.
sur-actualisation expression Appelé sur pull-to-refresh.
sur défilement expression Appelé lors du défilement.
scrollbar-x booléen La barre de défilement horizontale doit-elle être affichée? La valeur par défaut est true.
barre de défilement-y chaîne La barre de défilement verticale doit-elle être affichée? La valeur par défaut est true.
zoom booléen Utilisé pour appliquer le pincement pour zoomer.
zoom min entier Valeur de zoom minimale.
zoom max entier Valeur de zoom maximale.
scrollbar-x booléen Utilisé pour activer le rebond. La valeur par défaut sur IOS est true, sur Android false.

DEFILEMENT infini

Un défilement infini est utilisé pour déclencher un certain comportement lorsque le défilement passe en bas de la page. L'exemple suivant montre comment cela fonctionne. Dans notre contrôleur, nous avons créé une fonction pour ajouter des éléments à la liste. Ces éléments seront ajoutés lorsqu'un parchemin franchit 10% du dernier élément chargé. Cela continuera jusqu'à ce que nous atteignions 30 éléments chargés. Chaque fois que le chargement est terminé,on-infinite diffusera scroll.infiniteScrollComplete un événement.

Code HTML

<ion-list>
   <ion-item ng-repeat = "item in items" item = "item">Item {{ item.id }}</ion-item>
</ion-list>

<ion-infinite-scroll ng-if = "!noMoreItemsAvailable" on-infinite = "loadMore()" 
   distance = "10%"></ion-infinite-scroll>

Code du contrôleur

.controller('MyCtrl', function($scope) {
   $scope.items = [];
   $scope.noMoreItemsAvailable = false;
   
   $scope.loadMore = function() {
      $scope.items.push({ id: $scope.items.length}); 

      if ($scope.items.length == 30) {
         $scope.noMoreItemsAvailable = true;
      }
   
      $scope.$broadcast('scroll.infiniteScrollComplete');
   };
})

D'autres attributs peuvent également être utilisés avec ion-infinite-scroll. Certains d'entre eux sont répertoriés dans le tableau ci-dessous.

Attributs de défilement

Attribut Type Détails
sur-infini expression Ce qui devrait être appelé lorsque vous faites défiler vers le bas.
distance chaîne La distance par rapport au bas nécessaire pour déclencher une expression infinie.
fileur chaîne Quel spinner doit être affiché lors du chargement
contrôle immédiat Booléen Doit-on appeler 'on-infini' lorsque l'écran est chargé

Délégué de défilement

Ionic propose un délégué pour un contrôle total des éléments de défilement. Il peut être utilisé en injectant un$ionicScrollDelegate service au contrôleur, puis utilisez les méthodes qu'il fournit.

L'exemple suivant montre une liste déroulante de 20 objets.

Code HTML

<div class = "list">
   <div class = "item">Item 1</div>
   <div class = "item">Item 2</div>
   <div class = "item">Item 3</div>
   <div class = "item">Item 4</div>
   <div class = "item">Item 5</div>
   <div class = "item">Item 6</div>
   <div class = "item">Item 7</div>
   <div class = "item">Item 8</div>
   <div class = "item">Item 9</div>
   <div class = "item">Item 10</div>
   <div class = "item">Item 11</div>
   <div class = "item">Item 12</div>
   <div class = "item">Item 13</div>
   <div class = "item">Item 14</div>
   <div class = "item">Item 15</div>
   <div class = "item">Item 16</div>
   <div class = "item">Item 17</div>
   <div class = "item">Item 18</div>
   <div class = "item">Item 19</div>
   <div class = "item">Item 20</div>
</div>

<button class = "button" ng-click = "scrollTop()">Scroll to Top!</button>

Code du contrôleur

.controller('DashCtrl', function($scope, $ionicScrollDelegate) {

   $scope.scrollTop = function() {
      $ionicScrollDelegate.scrollTop();
   };
})

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

Lorsque nous tapons sur le bouton, le défilement sera déplacé vers le haut.

Maintenant, nous allons passer en revue tous les $ionicScrollDelegate méthodes.

Déléguer les méthodes

Méthode Paramètres Type Détails
scrollTop (paramètre) devraitAnimer booléen Le défilement doit être animé.
scrollBottom (paramètre) devraitAnimer booléen Le défilement doit être animé.
scrollTo (paramètre1, paramètre2, paramètre3) gauche, haut, devraitAnimer nombre, nombre, entier Les deux premiers paramètres déterminent la valeur du décalage des axes x et y.
scrollBy (paramètre1, paramètre2, paramètre3) gauche, haut, devraitAnimer nombre, nombre, entier Les deux premiers paramètres déterminent la valeur du décalage des axes x et y.
zoomTo (paramètre1, paramètre2, paramètre3, paramètre4) niveau, animer, origineGauche, origineTop nombre, booléen, nombre, nombre level est utilisé pour déterminer le niveau de zoom. originLeft et originRight coordonnées où le zoom doit avoir lieu.
zoomBy (paramètre1, paramètre2, paramètre3, paramètre4) facteur, animer, origineGauche, origineTop nombre, booléen, nombre, nombre factor est utilisé pour déterminer le facteur de zoom. originLeft et originRight coordonnées où le zoom doit avoir lieu.
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.
anchorScroll (paramètre1) devraitAnimer booléen Il fera défiler jusqu'à l'élément avec le même identifiant que le window.loaction.hash. Si cet élément n'existe pas, il défilera vers le haut.
freezeScroll (paramètre1) devraitFreeze booléen Utilisé pour désactiver le défilement pour un défilement particulier.
freezeAllScrolls (paramètre1) devraitFreeze booléen Utilisé pour désactiver le défilement pour tous les parchemins de l'application.
getScrollViews () / objet Renvoie l'objet scrollView.
$ getByHandle (paramètre1) manipuler chaîne Utilisé pour connecter des méthodes à la vue de défilement particulière avec la même poignée. $ionicScrollDelegate. $getByHandle('my-handle').scrollTop();