在另一个工厂中使用工厂是未定义的-AngularJS

在另一个工厂中使用工厂是未定义的-AngularJS,angularjs,Angularjs,我有一个名为ReportService和IndexService的工厂。我想在ReportService的内部使用IndexService 但是在ReportService中,它表示IndexService是未定义的。我不太清楚为什么 以下是我目前的代码: indexService.js angular.module('IndexService', []).factory('IndexService', ['$http', function ($http) { return {

我有一个名为
ReportService
IndexService
的工厂。我想在
ReportService
的内部使用
IndexService

但是在
ReportService
中,它表示
IndexService
未定义的。我不太清楚为什么

以下是我目前的代码:

indexService.js

angular.module('IndexService', []).factory('IndexService', ['$http', function ($http) {
    return {
        // Sending npm config from server (node) to front-end as JSON so we can use it in front-end.
        // See localhost.json.
        getConfig: function() {
            return $http.get("/api/get-config");
        }
    }
}]);
angular.module('ReportService', []).factory('ReportService', ['$http', 'IndexService', function ($scope, $http, IndexService) {
    // Sending npm config from server (node) to front-end as JSON so we can use it in front-end.
    // See localhost.json.
    IndexService.getConfig()
    .then(function(response) {
        var configs = response.data
    }); 

    return {
        generateExcelReport: function(searchCriteriaList) {
            var requestConfig = {
                responseType: "arraybuffer",
                headers: { "Content-Disposition": "attachment" }
            };

            // I want to call IndexService.getConfig()
            // so I can change my base URL and port based on environment. My configs are in node.js back-end
            var url = configs.url;
            var port = configs.port;

            return $http.post(url + ":" port + "/my-api-link", searchCriteriaList, requestConfig);
        },
    }
}]);
reportService.js

angular.module('IndexService', []).factory('IndexService', ['$http', function ($http) {
    return {
        // Sending npm config from server (node) to front-end as JSON so we can use it in front-end.
        // See localhost.json.
        getConfig: function() {
            return $http.get("/api/get-config");
        }
    }
}]);
angular.module('ReportService', []).factory('ReportService', ['$http', 'IndexService', function ($scope, $http, IndexService) {
    // Sending npm config from server (node) to front-end as JSON so we can use it in front-end.
    // See localhost.json.
    IndexService.getConfig()
    .then(function(response) {
        var configs = response.data
    }); 

    return {
        generateExcelReport: function(searchCriteriaList) {
            var requestConfig = {
                responseType: "arraybuffer",
                headers: { "Content-Disposition": "attachment" }
            };

            // I want to call IndexService.getConfig()
            // so I can change my base URL and port based on environment. My configs are in node.js back-end
            var url = configs.url;
            var port = configs.port;

            return $http.post(url + ":" port + "/my-api-link", searchCriteriaList, requestConfig);
        },
    }
}]);
app.js

angular.module('myApp', ['ngStorage', 'ngRoute', 'appRoutes', 'IndexController', 'IndexService', 'ReportController', 'ReportService', 'PackageController', 'PackageService', 'FarmService', 'DesignService', 'UserService', 'oitozero.ngSweetAlert', 'ui.select', 'ui.materialize', 'ngSanitize', 'ngFileSaver'])
my index.html脚本导入

<!-- Our Angular Controllers and Services JS -->
<script src="./js/controllers/indexController.js"></script>
<script src="./js/controllers/reportController.js"></script>
<script src="./js/controllers/nerdController.js"></script>
<script src="./js/controllers/packageController.js"></script>

<script src="./js/services/indexService.js"></script>
<script src="./js/services/reportService.js"></script>
<script src="./js/services/farmService.js"></script>
<script src="./js/services/packageService.js"></script>
<script src="./js/services/designService.js"></script>
<script src="./js/services/userService.js"></script>

<script src="./js/appRoutes.js"></script>
<script src="./js/app.js"></script>


请帮忙。我已经花了两个多小时在这上面了,我仍然找不到问题。。提前感谢:)

您需要先注射,如:

angular
    .module('ReportService')
    .factory('ReportService', ReportService);

ReportService.$inject = ['IndexService'];
function ReportService(IndexService) {
// You code blah blah here
}

至少我是这样做的。

否则我不喜欢您使用相同名称命名模块和工厂的样式。以后它可能会误导你们或其他从事项目工作的开发人员。我会将他们添加到“服务”模块下。我明白了!。谢谢你的批评和回答,@Andris=)