Angular 'Unknown provider error' (工厂文件)当我使用 ngroute

Angular 'Unknown provider error' (of a factory file) when I use ngroute

我想选择这个 html 页面:

<h2 class="sub-header" style="color:#4e67c3;">Elenco dipendenti</h2>
          <div class="table-responsive">
            <table id="thetable">
                
             
                <tr> 
                    <th class="th2">Nome</th>  
                    <th class="th2">Cognome</th>  
                    <th class="th2">Data di Nascita</th>   
                    <th class="th2">Telefono</th>  
                    <th class="th2">&nbsp;&nbsp;Sesso&nbsp;&nbsp;</th> 
                    <th class="th2">&nbsp;StaffId&nbsp;</th>
                    <th class="th2">Email</th> 
             </tr> 
             
              
              <tr ng-repeat="staff in staffs">  
                 
           <td> {{ a }}</td> 
            <td> {{ staff.name }}</td>  
            <td> {{ staff.surname }}</td>    
            <td> {{ staff.birthDate }}</td>
            <td> {{ staff.phone }}</td> 
            
   
            <td>
                <div ng-switch on="staff.gender">
                <span ng-switch-when="true">Uomo</span>
                <span ng-switch-when="false">Donna</span>
                </div>
            </td>
                    
            
            <td> {{ staff.idstaff }}</td>  
            <td> {{ staff.staffLogin.email }}</td> 
    

            </tr>  
          
            </table>

      <script src="./scripts/bootstrap.min.js.download"></script>
    <script src="./scripts/docs.min.js.download"></script>
               
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js"></script> 
 <!-- <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-animate.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-aria.js"></script> -->

             
      <script src="scripts/rest-services.js"></script>
    <script src="scripts/jquery.js"></script>
    <script src="bootstrap-3.3.7-dist/js/bootstrap.js"></script>
    <script src="scripts/angular.js"></script>
  <!--  <script src="scripts/emailchecker.js"></script>  --> 
    <script src="scripts/angular-bootstrap-datepicker.js" charset="utf-8"></script>
   <!-- <script src="scripts/number-directive.js"></script> -->
    <script type="application/javascript"></script>

在此页面中,当我单击一个按钮时:

<!DOCTYPE html>
<!-- saved from url=(0069)https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/ -->
<html lang="en"><head><meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <meta name="description" content="">
    <meta name="author" content="">

    <link rel="shortcut icon" href="images/puzzle.png" />
      
    <link rel="stylesheet" href="bootstrap/css/bootstrap.css" />
<!--    <link rel="stylesheet" href="styles/angular-bootstrap-datepicker.css" /> --> <!-- penso di poterlo togliere -->
    <link rel="stylesheet" href="styles/mainBoot.css">
    <link rel="stylesheet" href="styles/scrollbar.css">
    <link rel="stylesheet" href="styles/noscroll_numberfield.css">
    
 
 

  <!--  <script src="scripts/emailchecker.js"></script>  --> 
 
 <!--   <script src="scripts/angular-bootstrap-datepicker.js" charset="utf-8"></script> -->
   <!-- <script src="scripts/number-directive.js"></script> -->
    <script type="application/javascript"></script>
    
    <title>Pannello Amministratore</title>

    <!-- Bootstrap core CSS -->
    <link href="./styles/bootstrap.min.css" rel="stylesheet">

    <!-- Custom styles for this template -->
    <link href="./styles/dashboard.css" rel="stylesheet">

    <!-- Just for debugging purposes. Don't actually copy this line! -->
    <!--[if lt IE 9]><script src="../../assets/js/ie8-responsive-file-warning.js"></script><![endif]-->

    <!-- HTML5 shim and Respond.js IE8 support of HTML5 elements and media queries -->
    <!--[if lt IE 9]>
      <script src="https://oss.maxcdn.com/libs/html5shiv/3.7.0/html5shiv.js"></script>
      <script src="https://oss.maxcdn.com/libs/respond.js/1.4.2/respond.min.js"></script>
    <![endif]-->
  <style id="holderjs-style" type="text/css"></style></head>

  <body ng-app="StaffManagement" background="images/sfondoblu3.png">

    <div class="navbar navbar-inverse navbar-fixed-top" role="navigation">
      <div class="container-fluid">
        <div class="navbar-header">
          <button type="button" class="navbar-toggle" data-toggle="collapse" data-target=".navbar-collapse">
            <span class="sr-only">Toggle navigation</span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
            <span class="icon-bar"></span>
          </button>
          <a class="navbar-brand">FDDispenser</a>
        </div>
        <div class="navbar-collapse collapse">
          <ul class="nav navbar-nav navbar-right">
            <li><a href="fixed_admin.html#/">Pannello Amministratore</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/#">Settings</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/#">Profile</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/#">Help</a></li>
          </ul>
          <form class="navbar-form navbar-right">
            <input type="text" class="form-control" placeholder="Search...">
          </form>
        </div>
      </div>
    </div>

    <div class="container-fluid">
      <div class="row">
        <div class="col-sm-3 col-md-2 sidebar">
          <ul class="nav nav-sidebar">
           <li class="active"><a  href="#/showemp">Mostra Dipendenti</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/#">Mostra Catalogo</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/#">Mostra Macchinette</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/#">Mostra Acquisti</a></li>
          </ul>
          <ul class="nav nav-sidebar">
            <li class="active"><a href="edit_employee.html">Aggiungi/Modifica Dipendente</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Crea/Modifica Catalogo</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Famiglia</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Categoria</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Produttore</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Ingrediente</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Fabbrica di produzione</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Macchinetta</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Tipologia Macchinetta</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Aggiungi/Modifica Accessori</a></li>
          </ul>
          <ul class="nav nav-sidebar">
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Assegna Macchinetta a Dipendente</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Posiziona Macchinetta sul Territorio</a></li>
            <li><a href="https://hackerstribe.com/guide/IT-bootstrap-3.1.1/examples/dashboard/">Assegna Prodotti a Macchinetta</a></li>
          </ul>
        </div>
        <div class="col-sm-9 col-sm-offset-3 col-md-10 col-md-offset-2 main">
            
          <div ng-view></div>
            
            
        </div>
      </div>
    </div>

    <!-- Bootstrap core JavaScript
    ================================================== -->
    <!-- Placed at the end of the document so the pages load faster -->
  <!--  <script src="./Dashboard Template for Bootstrap_files/jquery.min.js.download"></script> -->
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js"></script> 
 <!-- <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-animate.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-aria.js"></script> -->

      

    <script src = "https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-route.min.js"></script>
    <script src="scripts/main-admin.js"></script>

    <script src="scripts/jquery.js"></script>
    <script src="bootstrap-3.3.7-dist/js/bootstrap.js"></script>
      
    <script src="./scripts/bootstrap.min.js.download"></script>
    <script src="./scripts/docs.min.js.download"></script>
        

</body></html>

ngroute 函数在这个名为 "main-admin.js":

的 js 文件中

var app = angular.module("StaffManagement", ["ngRoute"]);
app.config(function($routeProvider) {
    $routeProvider
    .when("/", {
        templateUrl : "home_admin.html"
    })
    .when("/showemp", {
        templateUrl : "provaEmp.html",
        controller: "StaffController"
    })
    .when("/paris", {
        templateUrl : "paris.htm"
    });
});


app.controller("StaffController", function($scope, $filter, $http, restService) {  
                

                
    $scope.name = "ciao";
    restService.allstaffworking(_getstaff, _error);
     function _getstaff(response){
                    if (response.data == ""){
                        console.log("Accesso non autorizzato")
                    }
                    $scope.staffs = response.data;  
                }
           
                function _success(response) {  
                   // console.log(staff.name);
                    console.log("successo");
                    
                    _refreshStaffData();  
                    _clearFormData();
                    _showSB();
                    console.log("cleared");
                
                }  
           
             
      }); 

当我单击按钮 "Mostra Dipendenti" 时,应用程序从主 admin.js 显示 "provaEmpl.html":

<h2 class="sub-header" style="color:#4e67c3;">Elensco dipendenti</h2>
          <div class="table-responsive">
            <table id="thetable">
                
             
                <tr> 
                    <th class="th2">Nome</th>  
                    <th class="th2">Cognome</th>  
              
                    <th class="th2">Telefono</th>  
                    <th class="th2">&nbsp;&nbsp;Sesso&nbsp;&nbsp;</th> 
                    <th class="th2">&nbsp;StaffId&nbsp;</th>
                    <th class="th2">Email</th> 
             </tr> 
             
              
                
                 

            <td> {{ name }}</td>  
            <td> {{ name }}</td>    
            
            <td> {{ name  }}</td> 
            
   

                   <td> {{ name  }}</td>  
            
            <td> {{ name  }}</td>  
            <td> {{ name  }}</td> 
    

            
          
            </table>

    
      <script src="./scripts/bootstrap.min.js.download"></script>
    <script src="./scripts/docs.min.js.download"></script>
               
    <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js"></script> 
 <!-- <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-animate.js"></script>
  <script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular-aria.js"></script> -->

 <script src="scripts/prova2.js"></script>
      <script src="scripts/rest-services.js"></script>
    <script src="scripts/jquery.js"></script>
    <script src="bootstrap-3.3.7-dist/js/bootstrap.js"></script>
    <script src="scripts/angular.js"></script>
  <!--  <script src="scripts/emailchecker.js"></script>  --> 
    <script src="scripts/angular-bootstrap-datepicker.js" charset="utf-8"></script>
   <!-- <script src="scripts/number-directive.js"></script> -->
    <script type="application/javascript"></script>

使用控制器"StaffController"。但是"StaffController"使用了另一个js文件的一些功能,一个factory文件,叫做rest-services.js:

var app = angular.module("StaffManagement");  
app.factory("restService", function($http, $window) {  
    var REST_URL = "http://localhost:8080/FoodDrinkDispener/rest/";
    var minutes = 20; // Reset when storage is more than 20 minutes
    var now = new Date().getTime();
    var setupTime = localStorage.getItem('setupTime');
    
    function _GetToken() {
        var token = localStorage.getItem("token");
        if (token !== null) 
            return JSON.parse(token);
        else
        console.log("Non c'è un token");
    }
    
    
    function _SetToken(CurrentToken) { //uso localStorage al posto si sessionStorage
        localStorage.setItem("token", (CurrentToken === null) ? null : JSON.stringify(CurrentToken));
    }
    
    function _deleteToken(idtoken, _success, _error) {  
       return $http({  
            method : 'DELETE',  
            url : REST_URL+'tokenstaff/'+idtoken,  
            headers : {  
                'Content-Type' : 'application/json'  
            }  
            }).then( _success, _error );  
        }
    
    function _RestSuccess(response) { //uso localStorage al posto si sessionStorage
        console.log("success"+response.status);
    }
    
    function _RestError(response) { //uso localStorage al posto si sessionStorage
        console.log("error"+response.status);
        if (response.status==404)
            $window.location.href="error404.html";
        else if(response.status==500)
            $window.location.href="error500.html";
            
    }
    
    function _DeleteByidLogin(loginform, _logsuccess, _logerror){
        return $http({  
                        method : 'GET',  
                        url : REST_URL+'stafflogin/'+loginform.email
                    }).then(function successCallback(response) {
                        _deleteToken(response.data, _logsuccess, _logerror);
                    }, function errorCallback(response) {  
                        console.log("ERRORE");
                        console.log(response.statusText);  
                    }); 
        }
    
    function _timerTokenControl(currentToken, _error){
        if(now-setupTime > minutes*60*1000) {
                if(currentToken!=null){
                    _deleteToken(currentToken.idtokenStaff, _error);
                }
                localStorage.clear();
                $window.location.href="login.html#/sessionExpired";
            }
    }
    


    
    return {
        login: function(loginform, _logsuccess, _logerror){
        _DeleteByidLogin(loginform, _logsuccess, _logerror);
            return $http({  
                method : 'POST',  
                url : REST_URL+'tokenstaff',
                data : angular.toJson(loginform), 
                }).then(function successCallback(response) {  
                    if (typeof response.data === 'object'){
                        var CurrentToken = response.data;
                        _SetToken(CurrentToken);
                        localStorage.setItem('setupTime', now)
                        
                        _logsuccess(response)
                        console.log("login andato a buon fine");
                        $window.location.href="fixed_admin.html";
                        return response.status;
                     }
                    else {
                        _SetToken(null);
                        _logerror(response);
                    }
                },function (response) {
                    _SetToken(null);
                    _logerror(response);
                }
                );
        },
        
        
        
             
        insertstaff: function(stafform, _giveLast, _error){
            var currentToken = _GetToken();

          /*  if(currentToken!=null){
                var Headers = {
                    token: currentToken.tokenStaff,
                };
            }*/
                
            _timerTokenControl(currentToken, _error);
            
            if (setupTime == null) {
                console.log("token scaduto");
                $window.location.href="login.html";
            }
            

            if (currentToken !== null) {
                return $http({  
                    method : 'POST',  
                    url : REST_URL+'staff',  
                    data : angular.toJson(stafform),  
                    headers : {  
                      token: currentToken.tokenStaff,
                        'Content-Type' : 'application/json'  
                    }  
                }).then( _giveLast, _error );
            }  else {
                    $window.location.href="login.html";
                    console.log("NON SEI LOGGATO!!!");
            }
        } ,
        
        
        /*
        insertstaff: function(stafform, _giveLast, _error){
            return $http({  
                method : 'POST',  
                url : REST_URL+'staff',  
                data : angular.toJson(stafform),  
                headers : {  
                            'Content-Type' : 'application/json'  
                }  
            }).then( _giveLast, _error );
            } ,
        */
        insertstafflogin: function(staffloginform, _giveLast, _error){
            var currentToken = _GetToken();

         /*   if(currentToken!=null){
                var Headers = {
                    token: currentToken.tokenStaff,
                };
            }*/
                
            _timerTokenControl(currentToken, _error);
            
            if (setupTime == null) {
                console.log("token scaduto");
                $window.location.href="login.html";
            }
            

            if (currentToken !== null) {
                return $http({  
                    method : 'POST',  
                    url : REST_URL+'stafflogin',  
                    data : angular.toJson(staffloginform),  
                    headers : {  
                        token: currentToken.tokenStaff,
                        'Content-Type' : 'application/json'  
                    }  
                }).then( _giveLast, _error ); //se errore allora DELETE staff, altrimenti sta stessa stafflogin
            }  else {
                    $window.location.href="login.html";
                    console.log("NON SEI LOGGATO!!!");
            }
            } ,
        
       
        
        allstaffworking: function(_getstaff, _error){
            var currentToken = _GetToken();

            if(currentToken!=null){
                var Headers = {
                    token: currentToken.tokenStaff,
                };
            }
                
            _timerTokenControl(currentToken, _error);
            
            if (setupTime == null) {
                console.log("token scaduto");
                $window.location.href="login.html";
            }
            

            if (currentToken !== null) {
            $http({  
                        method : 'GET',  
                        headers: Headers,
                        url : REST_URL+'staff/working'
                    }).then(function successCallback(response) {  
                        _getstaff(response)
                    }, function errorCallback(response) {  
                        console.log(response.statusText);  
                    });  
               }  else {
                    $window.location.href="login.html";
                    console.log("NON SEI LOGGATO!!!");
            }
        },
        
        laststaff: function(_postStaffLogin, _error){
            var currentToken = _GetToken();

            if(currentToken!=null){
                var Headers = {
                    token: currentToken.tokenStaff,
                };
            }
                
            _timerTokenControl(currentToken, _error);
            
            if (setupTime == null) {
                console.log("token scaduto");
                $window.location.href="login.html";
            }
            

            if (currentToken !== null) {
                return  $http({  
                    method : 'GET',
                    headers: Headers,
                    url : REST_URL+'staff/getlast'  
                                }).then(function successCallback(response) {
                                _postStaffLogin(response)
                                console.log(response);
                                return response.status; 
                                 //    console.log($scope.staffLast.idstaff);
                                 //   _postStaffLogin();
                            }, function errorCallback(response) {  
                                console.log(response.statusText);  
                            }); 
                }  else {
                    $window.location.href="login.html";
                    console.log("NON SEI LOGGATO!!!");
            }
        
    },
        
        deletestaff: function(stafform, _success, _error){
             var currentToken = _GetToken();

            if(currentToken!=null){
                var Headers = {
                    token: currentToken.tokenStaff,
                };
            }
                
            _timerTokenControl(currentToken, _error);
            
            if (setupTime == null) {
                console.log("token scaduto");
                $window.location.href="login.html";
            }
            

            if (currentToken !== null) {
                return $http({  
                    method : 'PUT',  
                    url : REST_URL+'staff',
                    data : angular.toJson(stafform),  
                    headers : {  
                        token: currentToken.tokenStaff,
                        'Content-Type' : 'application/json'  
                    }
                    }).then( _success, _error ); 
            }  else {
                    $window.location.href="login.html";
                    console.log("NON SEI LOGGATO!!!");
            }

            }
        
    }
    
    
});

问题出在这个"restService"工厂!它导致我这个错误:

angular.js:12520 Error: [$injector:unpr] Unknown provider: restServiceProvider <- restService <- StaffController
http://errors.angularjs.org/1.4.8/$injector/unpr?p0=restServiceProvider%20%3C-%20restService%20%3C-%20StaffController
    at https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:68:12
    at https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:4334:19
    at Object.getService [as get] (https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:4482:39)
    at https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:4339:45
    at getService (https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:4482:39)
    at invoke (https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:4514:13)
    at Object.instantiate (https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:4531:27)
    at https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:9197:28
    at link (https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular-route.min.js:7:268)
    at invokeLinkFn (https://ajax.googleapis.com/ajax/libs/angularjs/1.4.8/angular.js:8841:9) <div ng-view="" class="ng-scope">

事实上,如果我从 main-admin.js 中删除 "restService" 依赖项和 rest-services.js 的所有功能,它就可以工作..但我需要使用一些功能来自 rest-services.js 的 restService 工厂。我该怎么办?

尽量不要使用 var app = angular.module("StaffManagement") 只是 angular.module("StaffManagement").factory("restService", .....

您正在重新定义 var app

var app = angular.module("StaffManagement");

这意味着名为 StaffManagementapp 已经在某处创建,您正在访问它。但是,实际上你想创建这个。为此,您需要按如下方式使用。

var app = angular.module("StaffManagement", []);  

尝试按此顺序(从前到后)包含文件

jquery, angular, your js files

解决了在 fixed_admin.html 中导入此脚本的问题:

<script src="scripts/rest-services.js"></script>