2015-09-27 84 views
6

我知道这是一个常见问题,但我一直无法通过阅读先前提问的问题找到解决方案。AngularJS找不到我的控制器

我实际上得到两个错误,但第一个是关于角度不能找到我的控制器。 ?

http://errors.angularjs.org/1.4.2/ $喷油器/ NOMOD P0 = myApp.controllers

我的目录结构如下所示:

. 
└── static 
    ├── index.html 
    ├── js 
    │   ├── app.js 
    │   └── controllers.js 
    ├── lib 
    │   └── angular-ui-router.min.js 
    └── partials 
     ├── view1.html 
     └── view2.html 

我的索引文件如下所示:

<html ng-app="myApp"> 
    <head> 
     <meta charset="UTF-8"> 
     <title>Hello AngularJS</title> 
    </head> 
    <body> 
     <div ui-view></div> 
     <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.2/angular.min.js"></script> 
     <script type="text/javascript" src="//cdnjs.cloudflare.com/ajax/libs/angular.js/1.4.2/angular-route.min.js"></script> 
     <script type="text/javascript" src="lib/angular-ui-router.min.js"></script> 
     <script type="text/javascript" src="js/controllers.js"></script> 
     <script type="text/javascript" src="js/app.js"></script> 
    </body> 
</html> 

我app.js文件如下所示:

(function(angular) { 

    var app = angular.module('myApp', ['ui.router', 'myApp.controllers']); 

    app.config(function($stateProvider) { 
     $stateProvider.state('view1', { 
      url: '/view1', 
      templateUrl: 'partials/view1.html', 
      controller: 'View1Controller' 
     }).state('view2', { 
      url: '/view2', 
      templateUrl: 'partials/view2.html', 
      controller: 'View2Controller' 
     }); 
    }).run(function($state) { 
     $state.go('view2'); 
    }); 

})(angular); 

我controller.js文件如下所示:

(function(angular) { 
    var app = angular.module('myApp.controllers'); 

    app.controller('View1Controller', function($scope) { 
     $scope.data = 'my view 1'; 
    }); 

    app.controller('View2Controller', function($scope) { 
     $scope.data = 'my view 2'; 
    }); 

})(angular); 

而且第二error这可能是相关的。

如上所述,angular无法找到我的控制器。有没有人有关于我在做什么错误的线索?请让我知道是否需要粘贴更多的代码。

我已经在github上分享了代码,以防有人发现它更容易处理。

https://github.com/tonsV2/angular-ui.route/tree/master/src/main/resources/static

+0

努力改变装载脚本的顺序位置。文件'app.js'应该比'controllers.js'早加载。 – Niezborala

回答

7

在角angular.module()是setter和吸气剂。据(通过@DanAtkinson's comment)的angular.module文档:

传递一个参数检索现有angular.Module,而 传递多个参数创建一个新的angular.Module。

消气

var app = angular.module('myApp.controllers');使用模块作为吸气剂。

由于尚未创建模块myApp.controllers而失败。

二传手

要使用它作为一个二传手其更改为

var app = angular.module('myApp.controllers', []); // note the [] 
+1

[docs](https://docs.angularjs.org/api/ng/function/angular.module)不会使此获取/设置逻辑非常清晰,但在第一行中有以下语句: '传递一个参数会检索一个已存在的angular.Module,而传递多个参数将创建一个新的angular.Module'。 –

+1

谢谢。我补充说。 –