无法读取未定义的 属性 'index'

Cannot read property 'index' of undefined

我是 Angular 的新手,正试图在我的 Rails 应用程序中使用它。但是我得到了以下错误。

TypeError: Cannot read property 'index' of undefined

app.js代码

angular.module('ticket', ['ngResource', 'ui.router', 'templates'])
.controller('AppCtrl', ['$rootScope', function($rootScope) {
    var _this = this;
    return $rootScope.$on('$routeChangeSuccess', function(event, current, previous) {
        return $rootScope.pageTitle = $route.current.title;
    });
}])
.config(['$stateProvider', '$urlRouterProvider', function($stateProvider, $urlRouterProvider) {
    $stateProvider
        .state('home', {
            url: '/home',
            templateUrl: 'home/_home.html',
            controller: 'MainCtrl'
        })
        .state('members', {
            url: '/members',
            templateUrl: 'members/_members.html',
            controller: 'MemberCtrl'
        })
        .state('guards', {
            url: '/guards',
            templateUrl: 'guards/_guards.html',
            controller: 'GuardCtrl'
        })
        .state('tickets', {
            url: '/tickets',
            templateUrl: 'tickets/_tickets.html',
            controller: 'TicketCtrl'
        });
    $urlRouterProvider.otherwise('home')
}]);

memberCtrl.js 代码(成员目录内)

angular.module('ticket')
.factory('Member', ['$resource', function($resource) {
    return $resource("/members/:id", {id: "@id"}, {
        get: { method: 'GET'},
        save: { method: 'POST'},
        index: { method: 'GET', isArray: true},
        remove: { method: 'DELETE'},
        "delete": { method: 'DELETE'},
        update: { method: 'PUT'}
    });
}])
.controller('MemberCtrl', ['$scope', function($scope, Member) {
    console.log(Member.index());
    $scope.members = Member.index();
}]);

您需要在控制器中正确注入依赖项Member

.controller('MemberCtrl', ['$scope', 'Member', function($scope, Member) {
                                    //^^^^^^^^^^

而不是

.controller('MemberCtrl', ['$scope', function($scope, Member) {