HttpRequestInterceptor显示倍数相同的错误

时间:2016-11-30 07:42:42

标签: angularjs angular-http-interceptors angular-toastr

我添加了HttpRequestInterceptor我的AngularJS应用,每次请求失败时都会显示toastr

angular.module('spwApp.factories')
    .factory('httpRequestInterceptor', ['$q', '$injector', '$cookies', '$rootScope', function($q, $injector, $cookies, $rootScope) {
        return {
            'request': function($config) {
                var token = $cookies.get('token');
                $config.headers['Authorization'] = 'Bearer ' + token;
                return $config;
            },
            'responseError': function(rejection) {
                var toastr = $injector.get('toastr');
                var $state = $injector.get('$state');
                toastr.options = {
                    "closeButton" : true,
                    "preventDuplicates" : true,
                    "timeOut": "50000",
                    "extendedTimeOut" : "50000"
                };
                toastr.remove();
                switch (rejection.status) {
                    case 401:
                        if ($state.current.name != 'login') {
                            $state.go('login');
                            toastr.info('Re-enter username/password', 'Invalid sessions', toastr.options);
                        }
                        break;
                    case 403:
                        toastr.error('You do not have the rights', 'Forbidden', toastr.options)
                        $state.go('home');
                        break;
                    case 404:
                        toastr.error('Cannot found', '??', toastr.options);
                        $state.go('home');
                        break;
                    case 500:
                        toastr.error('Unexpected error', 'Hum...', toastr.options);
                        $state.go('home');
                        break;
                    case -1:
                        toastr.error('Connection to server not possible', 'Ouch...', toastr.options);
                        $state.go('home');
                        break;
                    default:
                        toastr.error('That is not supposed to land here', 'Oops...', toastr.options);
                        $state.go('home');
                        break;
                }
                return $q.reject(rejection);
            }
        };
    }]);

在某些页面上,我必须从服务器解析多个数据

.state('stateA', {
    url: '/urlToStateA',
    views: {
        'content@stateA': {
            templateUrl: 'app/stateA.html',
            controller: 'controllerA',
            controllerAs: 'vm',
            resolve: {
                dataA: ['myService', function(myService) {
                    return myService.getDataA();
                }],
                dataB: ['myService', function(myService) {
                    return myService.getDataB();
                }],
                dataC: ['myService', function(myService) {
                    return myService.getDataC();
                }]
            }
        }
    }
})

因此,当我的服务器关闭时,每个请求都会获得rejection.status == -1,然后显示toastr Connection to server not possible

问题是行toastr.remove();不起作用。它应该删除所有toastr但什么也不做。

如何在添加新的之前删除toastr?我可以用一些纯javascript替换不工作的toastr.remove()来手动选择并删除toastr吗?

1 个答案:

答案 0 :(得分:1)

您必须制作一些configuration changes以防止同时打开更多toastr's

toastr configurations可以在config角度函数中更改。

myApp.config(Config);

  function Config($httpProvider,toastrConfig) {

    $httpProvider.interceptors.push('interceptorService');

    angular.extend(toastrConfig, {
       autoDismiss: false,
       containerId: 'toast-container',
       maxOpened: 0,    
       newestOnTop: true,
       positionClass: 'toast-top-center',
       preventDuplicates: false,
       preventOpenDuplicates: true,
       target: 'body'
    });

  }  

preventOpenDuplicates: true 此行会阻止同一条消息多次显示。

来自Customizing the toastr link reference

  • autoDismiss:如果设置,则只显示最近的maxOpened toast
  • containerId:要添加祝酒词的容器名称(将为您创建容器)。
  • maxOpened:一次显示的最大敬酒数。
  • newestOnTop:在旧的祝酒词之上添加新的祝酒词。穿上假装把它们放在底部。
  • positionClass:添加祝酒词的位置。
  • preventDuplicates:防止最后一片吐司重复。
  • preventOpenDuplicates:防止重复开放式祝酒词。
  • target:放置toastr容器的元素。