angularjs获取以前的路由路径

前端之家收集整理的这篇文章主要介绍了angularjs获取以前的路由路径前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
<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我的后退按钮更改为主视图中的菜单链接

所以我的问题是如何获得以前的路由路径在控制器或更好的方式来实现这一点?

我创建了一个Plunker演示我的问题。请检查。

该替代方案还提供后退功能

模板:

<a ng-click='back()'>Back</a>

模块:

myModule.run(function ($rootScope,$location) {

    var history = [];

    $rootScope.$on('$routeChangeSuccess',function() {
        history.push($location.$$path);
    });

    $rootScope.back = function () {
        var prevUrl = history.length > 1 ? history.splice(-2)[0] : "/";
        $location.path(prevUrl);
    };

});

猜你在找的Angularjs相关文章