<h1>{{header}}</h1>
<!-- This Back button has multiple option -->
<!-- In home page it will show menu -->
<!-- In other views it will show back link -->
<a ng-href="{{back.url}}">{{back.text}}</a>
<div ng-view></div>
В моей конфигурации модуля
$routeProvider.
when('/', {
controller:HomeCtrl,
templateUrl:'home.html'
}).
when('/menu', {
controller:MenuCtrl,
templateUrl:'menu.html'
}).
when('/items', {
controller:ItemsCtrl,
templateUrl:'items.html'
}).
otherwise({
redirectto:'/'
});
Контроллеры
function HomeCtrl($scope, $rootScope){
$rootScope.header = "Home";
$rootScope.back = {url:'#/menu', text:'Menu'};
}
function MenuCtrl($scope, $rootScope){
$rootScope.header = "Menu";
$rootScope.back = {url:'#/', text:'Back'};
}
function ItemsCtrl($scope, $rootScope){
$rootScope.header = "Items";
$rootScope.back = {url:'#/', text:'Back'};
}
Как вы можете видеть в моих контроллерах, я жестко закодировал обратный URL-адрес и текст (на самом деле мне не нужен текст, как изображение). Таким образом, я обнаружил, что в некоторых случаях кнопка перемещается некорректно. Я не могу использовать кнопку history.back()
coz my back, чтобы перейти к ссылке меню в домашнем виде.
Итак, мой вопрос в том, как получить предыдущий маршрут маршрута в контроллерах или лучший способ добиться этого?
Я создал демонстрацию Plunker моей проблемы. Пожалуйста, проверьте это.