Я переношу свое приложение на основе AngularJS на использование ui-router вместо встроенной маршрутизации. Я настроил его, как показано ниже
.config(function($stateProvider, $urlRouterProvider) {
$urlRouterProvider.otherwise('/home');
$stateProvider
.state('home', {
url: '/home',
templateUrl : 'views/home.html',
data : { pageTitle: 'Home' }
})
.state('about', {
url: '/about',
templateUrl : 'views/about.html',
data : { pageTitle: 'About' }
})
});
Как я могу использовать переменную pageTitle для динамической установки заголовка страницы? Используя встроенную маршрутизацию, я мог
$rootScope.$on("$routeChangeSuccess", function(currentRoute, previousRoute){
$rootScope.pageTitle = $route.current.data.pageTitle;
});
а затем привяжите переменную в HTML, как показано ниже
<title ng-bind="$root.pageTitle"></title>
Есть ли подобное событие, к которому я могу подключиться с помощью ui-router? Я заметил, что есть функции onEnter и onExit, но они, кажется, привязаны к каждому состоянию и потребуют от меня повторения кода для установки переменной $ rootScope для каждого состояния.