[英]$injector:unpr angularjs when injecting a service in the controller
[英]Injecting service to controller gets unpr error
当我在控制器中注入服务时出现了unpr错误,我研究了一种实现方法,但确实没有任何进展
这是我的app.js
'use strict';
var myApp = angular.module('myapp', [
'ngRoute','ui.bootstrap'
]);
angular.module('myapp')
.config(['$routeProvider','$locationProvider',
function($routeProvider,$locationProvider) {
$routeProvider
.when('/', {
templateUrl: 'views/home.html',
controller: 'mainController'
})
.when('/home',{
templateUrl: 'views/home.html',
controller: 'mainController'
})
.otherwise({
redirectTo: '/'
});
// use the HTML5 History API
$locationProvider.html5Mode(true);
}]);
angular.module('myapp')
.run(function($rootScope){
$rootScope = 'link to api';
});
这是我的service.js
'use strict';
/*
$http is neccessity param to make rest calls
$q variable to hold a promise
$rootscope handle scope
*/
angular.module('myapp')
.service('task',['$http','$q','$rootscope',function($http, $q, $rootscope){
var task = this;
task.itemList = {}
task.getItem = function (){
var defer = $q.defer();
$http.get('by_pass.php' + $rootscope.itemUrl)
.success(function (res){
task.itemlist = res;
defer.resolve(res);
})
.error(function (err, status) {
defer.reject(err);
});
return defer.promise;
}
return task;
}]);
这是我的controller.js
'use strict';
angular.module('myapp')
.controller('mainController',['$scope', '$rootScope', 'task', function($scope, $rootScope, task) {
console.log($rootScope.itemUrl);
$scope.init = function (){
$scope.perpx = 9;
$scope.itemPlaced = "0";
$scope.listSelectedItem = 1 ;
$scope.taskGetItem();
console.log('here');
}
$scope.taskGetItem = function (){
console.log('here too');
var getItemResult = task.getItem()
.then(function(res){
//when success
$scope.tasks = task.itemList;
console.log($scope.tasks);
}, function(err){
//error
});
}
$scope.init();
}]);
这就是我所拥有的
Error: [$injector:unpr] http://errors.angularjs.org/1.3.5/$injector/unpr?p0=%24rootscopeProvider%20%3C-%20%24rootscope%20%3C-%20task
谁能帮我。 我是angular的新手,我需要重构代码才能对其进行测试,但是我在这里有库存。 提前致谢。
更改:
.service('task',['$http','$q','$rootscope',function($http, $q, $rootscope){
至:
.service('task',['$http','$q','$rootScope',function($http, $q, $rootScope){
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.