伙计们,我是一个 AngularJS 新手,我正在尝试使用 Angular 创建一个绑定到模型层次结构的基本 HTML 层次结构。我的顶级模块如下所示:
angular.module('fooApp', ['ngResource', 'myList']) 在我的页面的根 div 中声明为 ng-app="fooApp"。
然后,我的页面中有如下所示的 HTML:
<my-item-list/>
我有第二个模块,如下所示:
var myList = angular.module('myList', []);
myList.directive('myItemList', function factory() {
var directiveDefinitionObject = {
priority: 0,
templateUrl: '/assets/partials/my-item-list.html',
replace: false,
transclude: false,
restrict: 'E',
scope: false,
controller: function($scope, $element, $attrs, $transclude) {
// No Op
$scope.foo = 'bar';
},
compile: function compile(tElement, tAttrs, transclude) {
return {
pre: function preLink(scope, iElement, iAttrs, controller) {
// No Op
},
post: function postLink(scope, iElement, iAttrs, controller) {
// No OP
}
}
},
link: function postLink(scope, iElement, iAttrs) {
// No Op
}
};
return directiveDefinitionObject;
});
部分 HTML 模板只包含一个表格和一个标记上的 ng-repeat。模板渲染得很好,但我的 JavaScript 控制台包含:
Error: No controller: myItemList
at Error (<anonymous>)
at h (http://localhost:9000/assets/javascripts/angular.min.js:41:458)
at i (http://localhost:9000/assets/javascripts/angular.min.js:43:415)
at http://localhost:9000/assets/javascripts/angular.min.js:48:191
at http://localhost:9000/assets/javascripts/angular.min.js:94:307
at h (http://localhost:9000/assets/javascripts/angular.min.js:78:33)
at http://localhost:9000/assets/javascripts/angular.min.js:78:266
at Object.e.$eval (http://localhost:9000/assets/javascripts/angular.min.js:88:347)
at Object.e.$digest (http://localhost:9000/assets/javascripts/angular.min.js:86:198)
at Object.e.$apply (http://localhost:9000/assets/javascripts/angular.min.js:88:506) <my-item-list>
我打算增加嵌套(例如,用另一个指令替换 HTML 部分模板中的'require' 属性到我的指令定义,我得到相同的“无控制器”错误消息,但带有我需要的任何名称(即使我尝试并要求 ngRepeat 或页面的主控制器)。