5

我的工厂看起来像:

'use strict';

angular.module('myApp')
  .factory('httpInterceptor',['$q','$location', '$rootScope', function($q, $location, $rootScope){
    return {
      response: function(response) {

        if(response.success === false) {
console.log("Redirecting");
            $location.path('/login');
            return $q.reject(response);
        }

        return response || $q.when(response);
      }
    }
}]);

它吐出日志,但不会更改路径。我能做些什么来实现这一点?

4

4 回答 4

10

$location的文档说:

请注意,setter 不会立即更新 window.location。相反,$location 服务知道范围生命周期,并在范围 $digest 阶段将多个 $location 突变合并为一个对 window.location 对象的“提交”。

因此,如果拒绝承诺对 有影响$location,那么您可能看不到预期的更改。

要强制在角度生命周期之外进行更改,您可以设置hash使用window.location,然后强制重新加载页面。当然,这将停止执行后面的任何代码并删除会话,但如果用户未登录,这可能是您想要的。

于 2013-11-02T01:36:28.630 回答
6

在某些情况下,如果 $location 在 Angular 的应用周期之外,它不会重定向。尝试将 $location 包装在 $apply 中。

$rootScope.$apply( function(){$location.path('/somelocatin'); } );
于 2013-11-02T01:55:35.637 回答
3

这个在 Angular 1.3.14 上为我工作

myServices.factory('Factory', ['$rootScope', '$location', function ($rootScope, $location) {
  // do something and redirect
  $location.path('path')
  $rootScope.$apply()
}])

请注意,$rootScope.$apply()$location.path('path')调用之后,由于某种原因,如上所述将其包装在 $apply 调用回调中不起作用。

于 2015-03-11T08:45:39.007 回答
0

尝试

$location.path('#/login');

代替

$location.path('/login');
于 2013-11-01T02:10:21.277 回答