前言,我有一个通过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);
我不确定处理此问题的最佳方法是什么。
答案 0 :(得分:0)
正如Radim Köhler所指出的那样,$ionicConfigProvider.views.maxCache(0)
解决了这个问题,而州cache:false
没有。你也可以这样做:
$scope.$on("$ionicView.afterLeave", function () {
$ionicHistory.clearCache();
});
对我来说,最好的方法就是选择一个控制器来完成它并完成它。