想寫一個全域的工具類,我在獨立的js檔案中聲明ng service(並載入到html)
(function(angular){
"use strict";
angular.module('testModule',function(){
return {
test : function(){
console.info('testModule is ready!');
}
}
});
})(window.angular);
然後想在appmodule的controller裡面注入testModule
,但提示注入失敗
var mainApp = angular.module('mainApp',[]);
mainApp.controller('homeController',['testModule',function(testModule){
testModule.test();
}]);
"Error: [$injector:unpr] Unknown provider: testModuleProvider
迷茫2017-05-15 17:15:05
謝邀,你寫的只對了30%。這裡涉及兩個話題:
angular.module('testModule')
和 angular.module('mainApp',[])
是两个不同的module,你想要在 mainApp
中使用 testModule
,那么你需要在 angular.module('mainApp', [ 'testModule' ])
導入這種相依性。
上面有人回答了:
(function(angular){
"use strict";
angular.module('testModule', []).factory('alertService', function() {
return {
test : function(){
console.info('testModule is ready!');
}
}
});
})(window.angular);
在使用時,可以:
var mainApp = angular.module('mainApp',[ 'testModule' ]);
mainApp.controller('homeController',['alertService',function(alertService){
alertService.test();
}]);
以上程式碼未經驗證,結構上應該沒有什麼問題,請自行除錯解決。
phpcn_u15822017-05-15 17:15:05
把你的service定義成一個module就可以了,例如:
var appServices = angular.module('myApp.services', []);
appServices.factory('alertService', function($rootScope) {
var alertService = {};
return alertService;
});