$广播到当前范围

时间:2016-01-29 04:21:17

标签: angularjs ionic-framework

前言,我有一个通过websocket连接到节点服务器的Ionic应用程序,节点服务器通过TCP套接字连接到C ++应用程序。我有这个服务连接并提供套接字,但也监视nack响应,以便它可以发出警告通知用户错误:

(function(){
  'use strict';

  angular.module('tacoCorp.services')
    .factory('Socket', Socket);

  Socket.$inject = ['socketFactory', 'OSDP', '$rootScope'];

  function Socket(socketFactory, OSDP, $rootScope) {
    var socket = io('localhost:3000');

    socket = socketFactory({ioSocket: socket});

    socket.on('connect', function() {
        console.log('connected');
    });

    socket.on('nack', function(data) {
        console.log(data);
        var error = OSDP.parse(data);
        $rootScope.$broadcast('nack', error);
    });

    return socket;
  }
}());

我在每个控制器中都有这个,所以它可以发出弹出窗口:

$scope.$on('nack', function(e, err) {
        console.log(err);
        var alertPopup = $ionicPopup.alert({
            title: 'Error',
            template: err.error
        });
    });

我的问题是即使我的状态/视图只有一个控制器,它也会多次触发。几乎就好像$destroy没有发生,或者它没有移除监听器。如果我这样做仍然会发生:

var nackListener = $scope.$on('nack', function(e, err) {
        console.log(e);
        var alertPopup = $ionicPopup.alert({
            title: 'Error',
            template: err.error
        });
    });

    $scope.$on('$destroy', nackListener);

我不确定处理此问题的最佳方法是什么。

1 个答案:

答案 0 :(得分:0)

正如Radim Köhler所指出的那样,$ionicConfigProvider.views.maxCache(0)解决了这个问题,而州cache:false没有。你也可以这样做:

$scope.$on("$ionicView.afterLeave", function () {
        $ionicHistory.clearCache();
    });

对我来说,最好的方法就是选择一个控制器来完成它并完成它。