我们有一个角度应用程序(SPA),它维护客户端用户会话(会话超时,不活动时间等)。该会话用于强制用户在会话因某种原因到期时重新登录。
会话过期由专用服务控制,该服务在会话终止,锁定或以其他方式更改状态时在$ rootScope上广播事件。
我们将侦听器添加到那些会将路由更改为相关页面(登录页面,解锁页面等)的会话状态更改事件。 我们正在使用angular-ui-router进行路由。
这很好,但是,特别是在Firefox中,如果在浏览器窗口/选项卡未激活(即最小化,在后台等)时发生会话状态更改,则页面未正确刷新。换句话说,您可以看到新页面的控件(例如用户名文本字段和密码字段),但不会看到新页面的背景,而是看到旧页面的背景。
它在Chrome和IE中完美运行,我们只在Firefox上看到此问题。此外,当浏览器窗口/选项卡处于活动状态时,它也可以在Firefox上完美运行。
有什么想法吗?
答案 0 :(得分:1)
让它成为另一种方式。 不要使用rootScope广播,只需使用当前状态获取服务中的var,然后返回具有此值的函数。
var userSession = 'Expired';
return {
getSessionState: function () {
return userSession;
}
}
并在您的控制器中观看它。因此,第一个摘要运行会将视图切换为您现在需要的视图。
$scope.$watch(function () {
return yourServiceName.getSessionState()
}, function (val) {
//you can check the val here and change the route
});
如果这没有帮助,请确保使用$ timeout(使用摘要的Angulars本机超时)并且没有任何设置超时(当浏览器窗口/选项卡未激活时停止JS超时,并且当选项卡时一次全部触发再次成为焦点,最终会出现Angular中的奇怪行为。