Używam dyrektywy md-virtual-repeat
z Angular Material
, aby mieć nieskończony zwój i muszę zastąpić jego funkcję demo $ z żądaniem $ http. Ale nie mogę znaleźć właściwego rozwiązania. W poniższym kodzie nieskończone przewijanie działa poprawnie, ale nie wyświetla danych z żądania http. Problem polega na tym, że nie znam sposobu wiązania wyniku $ http do infiniteItems.
Here jest 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));
}
}
};
});
})();
Dziękuję, działa. Ale nie wiem, dlaczego doLoad _ + = 20, kiedy idę w dół przewijania danych ładuje z dużym opóźnieniem, bardzo dół nigdy nie ładuje nie to samo dla doLoad _ + = 10. –
Cóż, w rzeczywistości tworzy element w DOM, ale ponieważ api zwraca 5 elementów, iirc, nie ma wystarczającej ilości danych do zainicjowania, więc są puste/puste. –
Dzięki, masz rację. Chcę tylko dodać jeszcze jeden punkt: Myślę, że zastąpienie 'danych' przez' obj.data' nie jest częścią rozwiązania, ponieważ użyłem 'success' zamiast' then' i zwraca dane nie wynikowe, ale używając 'concat 'jest częścią rozwiązania. Ponieważ kiedy usunę, że kod nie działa poprawnie. Ma wadę, ponieważ przechowuje wszystkie dane (wszystkie dane z widoku) w pamięci, nie tylko dane w widoku. –