Matériel angulaire infini défilement avec $requête http
Je suis en utilisant md-virtual-repeat
directive de Angular Material
ayant une infinité de défilement, et j'ai besoin de remplacer la démo $timeout fonction avec un $requête http. Mais je ne peux pas arriver à la bonne solution.
Dans le code ci-dessous, infinite scroll fonctionne bien, mais n'affiche pas les données de la requête http. Le problème est que je ne connais pas le moyen de liaison de $http résultat à infiniteItems.
Ici est le plunker.
Index.html
<body ng-app="infiniteScrolling" class="virtualRepeatdemoInfiniteScroll">
<div ng-controller="AppCtrl as ctrl" ng-cloak>
<md-content layout="column">
<md-virtual-repeat-container id="vertical-container" flex>
<div md-virtual-repeat="item in ctrl.infiniteItems" md-on-demand
class="repeated-item" flex>
{{item.id}}
</div>
</md-virtual-repeat-container>
</md-content>
</div>
</body>
JS:
(function () {
'use strict';
angular
.module('infiniteScrolling', ['ngMaterial'])
.controller('AppCtrl', function ($timeout,$scope,$http) {
this.infiniteItems = {
numLoaded_: 0,
toLoad_: 0,
items:[],
getItemAtIndex: function (index) {
if (index > this.numLoaded_) {
this.fetchMoreItems_(index);
return null;
}
return index;
},
getLength: function () {
return this.numLoaded_ + 5;
},
fetchMoreItems_: function (index) {
if (this.toLoad_ < index) {
this.toLoad_ += 20;
$http.get('items.json').success(function (data) {
var items = data;
for (var i = 0; i < items.length; i++) {
this.items.push(items[i].data);
}
this.numLoaded_ = this.toLoad_;
}.bind(this));
}
}
};
});
})();
Vous devez vous connecter pour publier un commentaire.
Celui-ci fonctionne:
plnkr
obj.data
, pas plaineobj
data
avecobj.data
ne fait pas partie de la solution que j'ai été en utilisantsuccess
au lieu dethen
et il renvoie des données pas de résultat, mais à l'aide deconcat
est une partie de la solution. Parce que lorsque je supprime que le code ne fonctionne pas correctement. Il a un inconvénient est qu'il stocker toutes les données (tous hors de la vue de données) dans la mémoire non seulement les données à afficher.success
vsthen
solution que j'ai présenté:success
eterror
ont été deprecatedSur tous les appels de l'api essayer d'obtenir météo la db a quelques enregistrements ou pas.
et d'ajouter que la condition dans fetchMoreItems_ fonction.
Dans notre code, nous obtenons les détails comme
l'extraction de la page sage de données.
est venu ici et j'ai vu @alessandro-buggin réponse qui a été très utile.
J'ai dû changer un peu, j'ai donc pensé à partager pour les autres pour les aider. J'avais besoin:
this.hold
)this.stop_
)this.hold
). Sur la vue que vous avez besoin d'utiliserng-hide
sur cet élément parce queng-if
éviter que l'élément ne jamais exister, donc il ne charge pas la première fois.Loin d'être parfait, mais fonctionne assez bien.
Note: mon service retourne un objet composé comme ceci:
obj = {elements: INTEGER, data: ARRAY}
où les éléments vous indique la longueur de la requête complète.