截获页面的关闭事件

想法来源

icbc的网银中发现,无论通过什么方式关闭网银页面,系统均会发出系统关闭的提示。

 

实现要素与难点

l  onbeforeunload

通过windowonbeforeunload可以截获到页面重新载入的事件,但是页面关闭、页面刷新、页面跳转都会触发此事件,无法确定是否关闭动作。此事件还可以阻止事件的执行。

l  Onunload

此事件触发在onbeforeunload之后。通过windowOnunload可以截获到页面重新载入的事件,但是页面关闭、页面刷新、页面跳转都会触发此事件,无法确定是否关闭动作。而且此事件无法阻止事件的执行。

 

最终实现思路

l  通过集合框架(frameset)将系统运行中需要重新载入的页面和不需要重新载入的页面区分开。

如果系统中的页面都是需要重新载入的,咱们可以自己定义一个不需要重新载入的页面放到frameset中,并将此页面容器frame的高度、宽度均设置为0(即不占用页面空间)。

 

l  禁用页面的整体重新载入。

具体参见 页面右键动作禁用

 

l  在不需要重新载入的页面中添加 onbeforeunloadonunload 事件。

可以在onbeforeunload事件中发出提示让用户确认是关闭页面否为意外事件。

可以在 onunload 事件中调用系统接口释放系统资源(如session)。

 

遗留问题

l  onbeforeunload 事件中的提示信息对话框只能用系统默认的,不能自定义。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值