В фрагменте кода я пытаюсь использовать контроллер FooCtrl
, который определен в включенном шаблоне app/foo.html
с использованием директивы common.script
.Использование контроллера, указанного в включенном шаблоне
angular.module('common.script', []).directive('script', function() {
return {
restrict: 'E',
scope: false,
compile: function(element, attributes) {
if (attributes.script === 'lazy') {
var code = element.text()
new Function(code)()
}
}
}
})
angular.module('app.templates', ['app/foo.html'])
angular.module("app/foo.html", []).run(function($templateCache) {
$templateCache.put("app/foo.html",
"<script data-script=\"lazy\">\n" +
" console.log('Before FooCtrl')\n" +
" \t angular.module('app').controller('FooCtrl', function($scope) {\n" +
" \t \t console.log('FooCtrl')\n" +
" \t })\n" +
"<\/script>\n" +
"<div data-ng-controller=\"FooCtrl\">app\/foo.html\n" +
"<\/div>"
)
})
angular.module('app', ['common.script', 'app.templates']).controller('ApplicationCtrl', function($scope) {
console.log('ApplicationCtrl')
})
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.5.3/angular.min.js"></script>
<div data-ng-app="app" data-ng-controller="ApplicationCtrl">
<div data-ng-include="'app/foo.html'"></div>
</div>
Но вместо ожидаемого результата FooCtrl
в консольных AngularJS бросает:
Error: [ng:areq] Argument 'FooCtrl' is not a function [...]
Я не понимаю, почему! Код в шаблоне выполняется до генерирования исключения, поэтому контроллер должен быть определен. Как я могу это исправить?