浅谈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 相关文章推荐
javascript中类的定义及其方式(《javascript高级程序设计》学习笔记)
Jul 04 Javascript
javascript获取下拉列表框当中的文本值示例代码
Jul 31 Javascript
兼容主流浏览器的jQuery+CSS 实现遮罩层的简单代码
Oct 14 Javascript
JavaScript数据结构与算法之栈详解
Mar 12 Javascript
详解Angular.js指令中scope类型的几种特殊情况
Feb 21 Javascript
详解使用React全家桶搭建一个后台管理系统
Nov 04 Javascript
jQuery+datatables插件实现ajax加载数据与增删改查功能示例
Apr 17 jQuery
微信小程序实现页面跳转传递参数(实体,对象)
Aug 12 Javascript
微信小程序实现二维码签到考勤系统
Jan 16 Javascript
es6数组includes()用法实例分析
Apr 18 Javascript
Angular短信模板校验代码
Sep 23 Javascript
JS实现简单贪吃蛇小游戏
Oct 28 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 欧美动漫
PHP 错误之引号中使用变量
2009/05/04 PHP
PHP+Mysql+jQuery中国地图区域数据统计实例讲解
2015/10/10 PHP
PHP钩子与简单分发方式实例分析
2017/09/04 PHP
用JTrackBar实现的模拟苹果风格的滚动条
2007/08/06 Javascript
js类定义函数时用prototype与不用的区别示例介绍
2014/06/10 Javascript
jQuery控制TR显示隐藏的三种常用方法
2014/08/21 Javascript
js中style.display=""无效的解决方法
2014/10/30 Javascript
jQuery源码分析之Callbacks详解
2015/03/13 Javascript
JavaScript事件类型中UI事件详解
2016/01/14 Javascript
JavaScript给每一个li节点绑定点击事件的实现方法
2016/12/01 Javascript
ionic实现下拉刷新载入数据功能
2017/05/11 Javascript
关于js中的鼠标事件总结
2017/07/11 Javascript
JS+Canvas绘制动态时钟效果
2017/11/10 Javascript
微信小程序开发注意指南和优化实践(小结)
2019/06/21 Javascript
react国际化化插件react-i18n-auto使用详解
2020/03/31 Javascript
vue下canvas裁剪图片实例讲解
2020/04/16 Javascript
手把手教你如何编译打包video.js
2020/12/09 Javascript
python 排序算法总结及实例详解
2016/09/28 Python
Python生成随机数组的方法小结
2017/04/15 Python
python利用lxml读写xml格式的文件
2017/08/10 Python
python中lambda()的用法
2017/11/16 Python
Python:Scrapy框架中Item Pipeline组件使用详解
2017/12/27 Python
django项目中使用手机号登录的实例代码
2019/08/15 Python
Python遍历字典方式就实例详解
2019/12/28 Python
Python学习笔记之装饰器
2020/08/06 Python
俄罗斯和世界各地的酒店预订:Hotels.com俄罗斯
2016/08/19 全球购物
凯特方迪化妆品官网:Kat Von D Beauty
2016/11/15 全球购物
美国滑雪板和装备购物网站:Skis.com
2018/12/20 全球购物
美国电子产品主要品牌的授权在线零售商:DataVision
2019/03/23 全球购物
北美最大的零售退货翻新商:VIP Outlet
2019/11/21 全球购物
英文自荐信格式
2013/11/28 职场文书
护士上岗前培训自我鉴定
2014/04/20 职场文书
2015年转正工作总结范文
2015/04/02 职场文书
2015年评职称个人工作总结
2015/10/15 职场文书
Python数据分析入门之数据读取与存储
2021/05/13 Python