浅谈window.onbeforeunload() 事件调用ajax


Posted in Javascript onJune 29, 2016

经常有这样的需求,就是在离开某个web页面时,用户不一定点注销,这样会导致会话不能及时销毁。为实现用户离开页面时,自动注销功能,需要在web页面的onbeforeunload事件处理函数中发送注销命令。这个地方大多用Ajax实现。有时还涉及到跨域访问的问题。这个地方就存在浏览器的兼容性问题。

浏览器在处理这个需求时的不兼容性有如下两点:

1、处理Ajax时的不兼容性,这里使用jQuery来解决。

2、在发送Ajax请求时的不兼容性

主要代码如下:

function logout() { 
        var logoutURL = "xxxx"; //用于注销用户的url 
        if (logoutURL == "") return; 
        var userAgent = navigator.userAgent.toLowerCase(); 
        if(userAgent.indexOf("msie")>-1) { //IE 
          $.ajax({ url: logoutURL, crossDomain: true, async: false, dataType: "jsonp" }); 
        }else { //FireFox Chrome 
          $.ajax({ url: logoutURL, async: false }); 
        } 
      } 
 
      window.onbeforeunload = function () { 
        logout(); 
      };

代码说明:

firefox在处理js时的安全级别较高,很多IE、Chrome中js可以使用的权限在Friefox中被限制,因此通过

if(userAgent.indexOf("msie")>-1) { //IE
          
        }else { //FireFox Chrome
          
        }

这段代码来判断当前浏览器类型。

针对Firefox、Chrome的兼容代码如下:

$.ajax({ url: logoutURL, async: false });

async需要设为false,即为同步,不能采用true异步的方式,否则请求有可能发不出去。其实Chrome也适用于下面针对IE的代码,在关掉浏览器时会自动发送注销命令,但是点浏览器的刷新按钮时也希望能自动注销用户时,Chrome就只能采用上面这行代码才能发出注销请求

针对IE的兼容代码如下:

$.ajax({ url: logoutURL, crossDomain: true, async: false, dataType: "jsonp" });

crossDomain设置为true是为了解决跨域访问问题,如果不存在这个问题,这个属性可以忽略。async属性最好也设成false,true也可以。dataType:"jsonp"这个属性也是为解决跨域访问问题,和crossDomain配合使用,不存在跨域问题,这两个属性可省略。

以上代码在IE9、Chrome27、Firefox21测试通过。

以上就是小编为大家带来的浅谈window.onbeforeunload() 事件调用ajax(标题)全部内容了,希望大家多多支持三水点靠木~

Javascript 相关文章推荐
Prototype使用指南之selector.js说明
Oct 26 Javascript
xml分页+ajax请求数据源+dom取结果实例代码
Oct 31 Javascript
一看就懂:jsonp详解
Jun 01 Javascript
Bootstrap基础学习
Jun 16 Javascript
jQuery三级下拉列表导航菜单代码分享
Apr 15 Javascript
JavaScript实现的背景自动变色代码
Oct 17 Javascript
url传递的参数值中包含&时,url自动截断问题的解决方法
Aug 02 Javascript
JS对HTML表格进行增删改操作
Aug 22 Javascript
JS优化与惰性载入函数实例分析
Apr 06 Javascript
Angular2 组件交互实例详解
Aug 24 Javascript
mongoose更新对象的两种方法示例比较
Dec 19 Javascript
JS中DOM元素的attribute与property属性示例详解
Sep 04 Javascript
json对象转为字符串,当做参数传递时加密解密的实现方法
Jun 29 #Javascript
jQuery ajax调用后台aspx后台文件的两种常见方法(不是ashx)
Jun 28 #Javascript
jQuery实现鼠标滚动图片延迟加载效果附源码下载
Jun 28 #Javascript
jqGrid用法汇总(全经典)
Jun 28 #Javascript
JavaScript实现时间倒计时跳转(推荐)
Jun 28 #Javascript
jQuery中text() val()和html()的区别实例详解
Jun 28 #Javascript
浅谈js的url解析函数封装
Jun 28 #Javascript
You might like
星际实力自我测试
2020/03/04 星际争霸
咖啡机如何保养和日常清洁?
2021/03/03 冲泡冲煮
使用NetBeans + Xdebug调试PHP程序的方法
2011/04/12 PHP
php对二维数组进行排序的简单实例
2013/12/19 PHP
php数据访问之查询关键字
2016/05/09 PHP
利用javascript实现一些常用软件的下载导航
2009/08/03 Javascript
jQuery validate 中文API 附validate.js中文api手册
2010/07/31 Javascript
JQuery入门—JQuery程序的代码风格详细介绍
2013/01/03 Javascript
javascript游戏开发之《三国志曹操传》零部件开发(二)人物行走的实现
2013/01/23 Javascript
jquery序列化表单以及回调函数的使用示例
2014/07/02 Javascript
js style动态设置table高度
2014/10/21 Javascript
jquery获取多个checkbox的值异步提交给php
2015/07/07 Javascript
基于AngularJS前端云组件最佳实践
2016/10/20 Javascript
jQuery阻止移动端遮罩层后页面滚动
2017/03/15 Javascript
浅谈JS中的常用选择器及属性、方法的调用
2017/07/28 Javascript
轻松理解vue的双向数据绑定问题
2017/10/30 Javascript
vue框架下部署上线后刷新报404问题的解决方案(推荐)
2019/04/03 Javascript
2019最新21个MySQL高频面试题介绍
2020/02/06 Javascript
redux处理异步action解决方案
2020/03/22 Javascript
SpringBoot在yml配置文件中配置druid的操作
2020/11/16 Javascript
Python简单生成随机姓名的方法示例
2017/12/27 Python
numpy中实现ndarray数组返回符合特定条件的索引方法
2018/04/17 Python
基于Python pip用国内镜像下载的方法
2018/06/12 Python
python获取栅格点和面值的实现
2020/03/10 Python
python能在浏览器能运行吗
2020/06/17 Python
python 装饰器的使用示例
2020/10/10 Python
解析HTML5的存储功能和web SQL的相关操作方法
2016/02/19 HTML / CSS
Html5基于canvas实现电子签名并生成PDF文档
2020/12/07 HTML / CSS
蛋白质世界:Protein World
2017/11/23 全球购物
出国考察邀请函
2014/01/21 职场文书
少儿节目主持串词
2014/04/02 职场文书
《天安门广场》教学反思
2014/04/23 职场文书
毕业生个人自荐书
2015/03/05 职场文书
手机销售员岗位职责
2015/04/11 职场文书
微软Win11什么功能最惊艳? Windows11新功能特性汇总
2021/11/21 数码科技
python图像处理 PIL Image操作实例
2022/04/09 Python