[英]AngularJS Getting Unknown provider error injecting a constant into a factory
尝试将constant
注入正在注入controller
的factory
,出现了unknown provider
的角度错误的unknown provider
错误。
angular.js:13920 Error: [$injector:unpr] Unknown provider: estimatingUtilitiesSettingsProvider <- estimatingUtilitiesSettings <- templateResolutionDataService
app.js:
angular
.module('main', [
'ngResource'
, 'angulartics'
, 'angulartics.appinsights'
, 'envModule'
, 'gettext'
, 'webModule'
, 'serviceModule'
])
.controller('testPageController', [
'$scope'
, '$http'
, '$resource'
, 'envModule'
, 'gettext'
, 'templateResolutionDataService'
, 'profileTemplateResolutionDataService'
, 'templateResolutionDataWithMultipleTemplatesService'
, 'partResolutionDataService'
, 'featureToggleService'
, 'recommendedResolutionDataService'
, 'profiledResolutionDataService'
, function ($scope, $http, $resource, envModule, gettext
, templateResolutionDataService
, profileTemplateResolutionDataService
, templateResolutionDataWithMultipleTemplatesService
, partResolutionDataService
, featureToggleService, recommendedResolutionDataService
, profiledResolutionDataService) {
//contents
}]);
templateResolutionDataService.js:
(function (angular) {
'use strict';
angular
.module('serviceModule', [
'webModule'
])
.factory('templateResolutionDataService', [
'gettext'
, 'estimateUtilitiesExtensionService'
, 'partResDataServiceSettings'
, 'estimatingUtilitiesSettings'
, function (gettext, estimatingUtilitiesService
, partResDataServiceSettings, estimatingUtilitiesSettings) {
}
]);
})(window.angular);
webModule.js:
(function (angular) {
'use strict';
angular
.module('webModule', [
'ng'
, 'ngResource'
,'miEnvironment'
,'gettext'
,'analyticsFilters'
,'touchEvents'
,'flyoutModule'
])
.constant('estimatingUtilitiesSettings', {
SourceKeys: {
'Template': 1
,'Part': 2
}
});
})(window.angular);
我一直在调整继承顺序,但似乎并没有解决这个问题。 有人知道我在做什么错吗,或者我怎么识别和解决它?
编辑:注释掉常量的声明(并用适当的值手动替换它的引用)确实允许应用程序继续进行到这一点,因此关于templateResolutionData.js
,这是阻止其执行的唯一方法。
我简化了您的代码,并在提琴上没有错误地运行了它
angular.module('main', ['webModule', 'serviceModule'])
.controller('testPageController', [
'$scope', '$http', 'templateResolutionDataService',
function($scope, $http, templateResolutionDataService) {
//contents
$scope.setting = templateResolutionDataService;
}
]);
(function(angular) {
'use strict';
angular.module('serviceModule', [
'webModule'
])
.factory('templateResolutionDataService', ['estimatingUtilitiesSettings',
function(estimatingUtilitiesSettings) {
var getSetting = function() {
return estimatingUtilitiesSettings.SourceKeys;
}
return getSetting();
}
]);
})(window.angular);
(function(angular) {
'use strict';
angular.module('webModule', [])
.constant('estimatingUtilitiesSettings', {
SourceKeys: {
'Template': 1,
'Part': 2
}
});
})(window.angular);
您已将miEstimatingUtilitiesSettings
误miEstimatingUtilitiesSettings
为EstimatingUtilitiesSettings
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.