0

我在几个不同的地方使用 ngInfiniteScroll 来显示联系人和未接来电。它遍历每个项目并添加一个 ng-click 以显示用户配置文件。滚动在所有位置都可以正常工作,直到您实际单击用户/呼叫。之后,无论是联系人还是电话,滚动都不会再次触发。我查看了他们的文档并看到了infinite-scroll-listen-for-event,我认为这是在单击事件后无限滚动重置所需的,但它似乎不起作用。我不知道我的 $emit 是否在错误的位置,还是什么?

HTML

            <md-list infinite-scroll="recent.moreContacts()" infinite-scroll-disabled="recent.busy" infinite-scroll-listen-for-event="resetInfiniteScrollList" infinite-scroll-distance="1" infinite-scroll-immediate-check="false" infinite-scroll-parent="true">
            <md-list-item ng-repeat="client in recent.clients | orderBy:'firstName'" ng-click="recent.viewCustomer(client.id)" class="repeater-list-item recent-session" layout="row" layout-align="start start" aria-label="View {{client.fullName}}'s profile">
                <div ng-if="client.avatar" class="md-avatar" style="background-image: url('{{client.avatar}}');"></div>
                <div ng-if="!client.avatar" class="md-avatar" ></div>
                <div class="md-list-item-text">
                    <h3>{{client.firstName}} {{client.lastName}} <span ng-if="!client.firstName">Unknown <small class="text-tertiary text-gray">(Customer: {{client.id}})</small></span></h3>
                </div>
            </md-list-item>
        </md-list>

加载联系人

                vm.moreContacts = function () {
                $timeout(function () {
                    $rootScope.closeSidenavs();
                    $rootScope.btnActive = 'contacts';
                    $mdSidenav('contacts').open();
                    $sessionStorage.currentTab = 'contacts';
                    if (vm.busy || vm.foundAllContacts || vm.contactsSearchActive) {

                    } else {
                        vm.busy = true;
                        api.get('/account/' + $rootScope.user.account.id + '/clients?page=' + vm.contactsNextPage, function (success, data) {
                            if (success) {
                                for (var i = 0; i < data.clients.length; i++) {
                                    vm.clients.push(data.clients[i]);
                                }

                                self.totalFound = data.totalFound;

                                self.lastPageLoaded = data.page;

                                if (data.clients.length === 25) {
                                    vm.contactsNextPage = vm.contactsNextPage += 1;
                                    console.log(vm.contactsNextPage);
                                }

                                if (vm.clients.length === self.totalFound) {
                                    vm.foundAllContacts = true;
                                }
                            } else {
                                vm.isClientsError = true;
                            }
                            vm.busy = false;
                        });
                    }
                }, 10);
            };

ng-点击功能

            vm.viewCustomer = function (clientId) {
            if (clientId > 0) {
                if ($mdMedia('xs') || $mdMedia('sm')) {
                    $rootScope.btnActive = '';
                    $rootScope.closeSidenavs();
                }

                $location.path(
                    "/customer/" + clientId + "/feed"
                );

                $rootScope.$emit('resetInfiniteScrollList');


                //vm.contactsSearchActive = false;
            }
        };
4

0 回答 0