Ионная бесконечная прокрутка в обратном направлении - PullRequest
0 голосов
/ 31 августа 2018

Я занимаюсь разработкой приложения для ионного чата с бесконечной прокруткой по ng-repeat для обработки ленивой нагрузки. Проблема заключается в следующем: бесконечная прокрутка начинается с верхней части представления (показывая первые самые старые чаты) и обрабатывает ленивую загрузку, когда пользователь прокручивает нижнюю часть, чтобы показать новейший чат. Мне нужна обратная логика для отображения первого последнего чата, а когда пользователь прокручивает вверх, в представлении отображаются старые чаты.

Резюме: мне нужна ионная бесконечная прокрутка, начинающаяся с нижней позиции, и когда пользователь прокручивает вверх, вид показывает самые старые чаты.

1 Ответ

0 голосов
/ 31 августа 2018

Я нашел пару примеров, которые могут помочь вам начать. JS Fiddle и аналогичный вопрос

Ниже приведен код из скрипки, я его не создавал.

function Main($scope) {
    $scope.items = [];

    var counter = 0;
    $scope.loadMore = function() {
        for (var i = 0; i < 5; i++) {
            $scope.items.unshift({id: counter});
            counter += 10;
        }
    };

    $scope.loadMore();
}

angular.module('scroll', []).directive('whenScrolled', ['$timeout', function($timeout) {
    return function(scope, elm, attr) {
        var raw = elm[0];

        $timeout(function() {
            raw.scrollTop = raw.scrollHeight;          
        });         

        elm.bind('scroll', function() {
            if (raw.scrollTop <= 100) { // load more items before you hit the top
                var sh = raw.scrollHeight
                scope.$apply(attr.whenScrolled);
                raw.scrollTop = raw.scrollHeight - sh;
            }
        });
    };
}]);

и HTML-код

<div id="fixed" when-scrolled="loadMore()">
  <ul>
    <li ng-repeat="i in items">{{i.id}}</li>
  </ul>  
</div>
...