В моем угловом приложении, у меня есть следующая структура маршрута:Угловой UI-маршрутизатор: государственный контролера ребенок не вызывался
.state('mapping', {
url: '/mapping',
templateUrl: 'app/components/mapping/mapping.html',
controller: 'MapCtrl as map',
abstract: true,
authenticate: true
})
.state('mapping.all', {
url: '',
templateUrl: 'app/components/mapping/partials/all.html',
authenticate: true
})
.state('mapping.project', {
url: '/:projectName',
templateUrl: 'app/components/mapping/partials/project.html',
controller: 'ProjectCtrl as proj',
authenticate: true
})
При доступе к mapping
состояния, mapping.all
нагрузка по умолчанию. Это в основном показывает список проектов, которые ссылаются на состояние mapping.project, как таковой:
<a ui-sref="mapping.project({projectId: project.id, projectName: project.name})">...</a>
Я хочу, чтобы вызвать ProjectCtrl
когда доступ mapping.project
для того, чтобы загрузить необходимые данные, но он даже не загружается , В этом фрагменте, ниже которого включает в себя только соответствующие данные, то alert
сообщение никогда не выскочит:
angular
.module('watera')
.controller('ProjectCtrl', Controller);
Controller.$inject = ['$stateParams', 'UserFactory', 'ProjectFactory'];
function Controller($stateParams, UserFactory, ProjectFactory) {
var proj = this;
activate();
function activate() {
alert('1');
}
}
Файл JS правильно связан и контроллер назван правильно. <div ui-view></div>
элемент расположен внутри mapping.html
, как показано ниже:
<div id="ribbon" class="no-print">
<div class="container-fluid">
<div class="row">
<div class="col-xs-12">
<strong>Mapping</strong>
<p class="text-muted">In this section...</p>
</div>
</div>
</div>
</div>
<div ui-view></div>
Почему этот контроллер не загружается?
EDIT: Он получает страннее, я переключил структуру:
.state('mapping', {
url: '/mapping',
templateUrl: 'app/components/mapping/mapping.html',
abstract: true,
authenticate: true
})
.state('mapping.all', {
url: '',
templateUrl: 'app/components/mapping/partials/all.html',
controller: 'MapCtrl as map',
authenticate: true
})
.state('mapping.project', {
url: '/:projectName',
templateUrl: 'app/components/mapping/partials/project.html',
controller: 'ProjectCtrl as proj',
authenticate: true
})
MapCtrl
И пока продолжает работать правильно, ProjectCtrl
до сих пор нет.
try 'controller: 'MapCtrl', controllerAs: 'map'' вместо' controller:' MapCtrl as map'' – guramidev
MapCtrl отлично работает, его ProjectCtrl не загружает. – Tiago