带异步请求的离子列表无限滚动问题

Redrom

我有一个由异步请求填充的离子列表的问题。

在HTML中,我有以下内容:

<ion-list class="list" ng-init="setDateRange('today');" >
          <!--IF NO ITEM IS FOUND -->
          <ion-item class="listCenter" ng-if="listData.length == 0 || listData.length == null">
              <h2>No data found, try to make few calls</h2>
          </ion-item>

          <ion-item class="item" ng-repeat="listDataItem in listData">
          <!--HTML CONTENT OF ITEM REMOVED FROM EXAMPLE -->
          </ion-item>

          <ion-infinite-scroll
                  icon="ion-loading-c"
                  distance="10%"
                  on-infinite="setDateRange('past')">
          </ion-infinite-scroll>
 </ion-list>

在ng-init中称为方法setDateRange方法,该方法在数据库上的单独方法中触发异步请求。

我认为,该问题可能是在updateList和createList的$ broadcast方法scroll.infiniteScrollComplete的实现中实现的

$scope.updateList = function() {
            console.log('Trying to update list');
            $timeout(function() {
                $scope.$apply(function() {
                    listData.forEach(function(item){
                        $scope.listData.push(item);
                        console.log("List length is "+ $scope.listData.length);
                    });
                    $ionicLoading.hide();
                });
                $scope.$broadcast('scroll.infiniteScrollComplete'); // should be removed in production
                $scope.$broadcast('scroll.resize');
            });
        };

        $scope.createList = function() {
            console.log('Trying to render list');
            alert("render");
            $timeout(function() {
                $scope.$apply(function() {
                    $scope.listData = listData;
                    console.log("List length is "+ $scope.listData.length);
                });
                // Infinite scroll broadcast should be here to avoid
                // triggering of the on-infinite event
                $scope.$broadcast('scroll.infiniteScrollComplete');
            });
            $ionicLoading.hide();
        };

因为在ng-init期间还触发了updateList方法,该方法无法完成,因为此时$ scope.listData不存在。

有人可以告诉我如何实施

$scope.$broadcast('scroll.infiniteScrollComplete') 

 $scope.$broadcast('scroll.resize');

以正确的方式?

谢谢你的帮助。

杰里米·威尔肯(Jeremy Wilken)

这里有一些注意事项,并在底部提供了一个演示链接,以显示完整的实现。如果没有完整的代码来测试并查看是否还有其他瓶颈,很难说出来。

  • 我不会使用ng-init,只是在您的控制器中调用它。然后,您确切地知道它何时发生。
  • 您可以通过在控制器中设置变量来初始化模型$scope.listData = [];
  • 您不必广播该scroll.resize事件。您应该将自己ionList放在ionContent或中ionScroll
  • class="item"<ion-item>是没有必要的,它会自动添加。
  • 您将需要ng-if在无限滚动中添加一个,以便它知道何时停止加载更多数据(请参见下面的示例)。
  • 您应该避免$scope.apply()始终使用,在这种情况下,无论如何您都不需要它。

这是我最近制作的一个Codepen,上面有一个使用infiniteScroll的好例子,它可以帮助您了解如何很好地使用它。http://codepen.io/gnomeontherun/pen/HJkCj

本文收集自互联网,转载请注明来源。

如有侵权,请联系[email protected] 删除。

编辑于
0

我来说两句

0条评论
登录后参与评论

相关文章