我是靠谱客的博主 安静大地,最近开发中收集的这篇文章主要介绍ajax同步的使用创场景,Ajax的同步调用场景——使用同步Ajax在 onunload 事件时通知服务器...,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

Ajax的同步调用场景——使用同步Ajax在 onunload 事件时通知服务器

(2012-04-09 01:59:06)

标签:

服务器

通知

杂谈

在一种场景下,server端维护了浏览器客户端的状态信息,当浏览器关闭时需要立刻通知server用户已经离开了,server端好清理状态。这种情况的典型案例就是:浏览器客户端的即时通信,即web

IM。因为用户关闭了窗口就表明用户已经不在线了,所有对话都结束了,server端和对话的另一方需要立刻知道这个状态变化。而一般情况下,server端并不需要立刻通知的情况,那就无所谓了,只要过期超时即可。要想在用户关闭浏览器后,server端得到通知,一般有两种做法:方法一:通过

javascript 轮询的方式向 server

发送心跳(使用异步ajax),server端记下上次心跳时间,server端Timer定期检查会话的心跳时间是否超时来判断用户是否已经离开了。这种方法的缺点是,要想即时通知就得把心跳间隔时间设得短,server端检查的时间也要短,这样会导致server端的负担大大增加,所能承载的用户就会较少。方法二:不采用发送心跳的方式,而是在用户关闭浏览器时,通知server即可。这样server端的负担就小了。window.onunload

= function(){ ajax.callServer();}重点说一下方法二的实现。首先,页面上注册onunload 事件。如

body元素的 onunload 属性,或直接设置 window.onunload 。注意是onunload

而不是onbeforeunload 事件,因为用户可以在onbeforeunload

事件时选择“取消”从而不关闭窗口,而onunload

事件意味着窗口肯定是要被关闭的。其次,在onunload事件中调用同步的ajax请求通知server,而非默认的异步ajax请求。因为调用异步的ajax请求在一些浏览器下无法真正使server得到通知,实际上根本无法保障!在发出了这个异步请求之后,浏览器就要

分享:

a4c26d1e5885305701be709a3d33442f.png喜欢

0

a4c26d1e5885305701be709a3d33442f.png赠金笔

加载中,请稍候......

评论加载中,请稍候...

发评论

登录名: 密码: 找回密码 注册记住登录状态

昵   称:

评论并转载此博文

a4c26d1e5885305701be709a3d33442f.png

发评论

以上网友发言只代表其个人观点,不代表新浪网的观点或立场。

最后

以上就是安静大地为你收集整理的ajax同步的使用创场景,Ajax的同步调用场景——使用同步Ajax在 onunload 事件时通知服务器...的全部内容,希望文章能够帮你解决ajax同步的使用创场景,Ajax的同步调用场景——使用同步Ajax在 onunload 事件时通知服务器...所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(55)

评论列表共有 0 条评论

立即
投稿
返回
顶部