使用分页时,AngularJS过滤会导致循环依赖性错误

时间:2013-08-24 03:01:39

标签: angularjs coldfusion pagination circular-dependency

这是我加载数据的方式

// Loads entire list of Metriclibs.

function HomeCtrl($scope, $http, $location) {
    $scope.data = [];
    $scope.pageSize = 100;
    $scope.currentPage = 0;
    $scope.lastPage = 0;


// This is async
$http.get('index.cfm/json/metriclib')
    .success(function(data) { 
        $scope.data = data;

        $scope.lastPage = Math.floor($scope.data.length/$scope.pageSize);
        })
    .error(function(data) { 
        console.log("Data load error");
        })  
        ;

$scope.go = function ( path ) {
    $location.path( path );
    };


$scope.numberOfPages=function(){
    return $scope.lastPage;                
    }

}

这是我如何在没有分页的情况下显示数据(这有效)

<tr ng-repeat="datum in data | filter:search  | limitTo:pageSize" class="odd">

这是设置起点的事情

<tr ng-repeat="datum in data   | startFrom:0 | limitTo:pageSize" class="odd">

当我做第二个时,我得到了:

[19:58:24.355] "Error: Circular dependency: 
getService@http://xxxxxxxx/toolbox_hacking/assets/angular.js:2855
@http://xxxxxxxx/toolbox_hacking/assets/angular.js:9604
filter@http://xxxxxxxx/toolbox_hacking/assets/angular.js:6157
_filterChain@http://xxxxxxxx/toolbox_hacking/assets/angular.js:6148
statements@http://xxxxxxxx/toolbox_hacking/assets/angular.js:6124
parser@http://xxxxxxxx/toolbox_hacking/assets/angular.js:6057
@http://xxxxxxxx/toolbox_hacking/assets/angular.js:6623
Scope.prototype.$eval@http://xxxxxxxx/toolbox_hacking/assets/angular.js:8057
ngRepeatWatch@http://xxxxxxxx/toolbox_hacking/assets/angular.js:13658
Scope.prototype.$digest@http://xxxxxxxx/toolbox_hacking/assets/angular.js:7935
Scope.prototype.$apply@http://xxxxxxxx/toolbox_hacking/assets/angular.js:8143
done@http://xxxxxxxx/toolbox_hacking/assets/angular.js:9170
completeRequest@http://xxxxxxxx/toolbox_hacking/assets/angular.js:9333
createHttpBackend/</xhr.onreadystatechange@http://xxxxxxxx/toolbox_hacking/assets/angular.js:9304

1 个答案:

答案 0 :(得分:0)

事实证明我的controller.js

var Home = angular.module("Home", []);

除了

app.js

var Home = angular.module("Home", []);

controller.js擦除了我的客户过滤器