关闭页面时window.location事件未执行的原因分析及解决方案


Posted in Javascript onSeptember 01, 2014

1、问题描述:

JS中定义widow.location = function(),页面关闭时,logout()函数未执行。 

window.onunload = function() {
    logout();
  }

function logout(reqParam, callback){
    var userManageServiceUrl = "http://" + getServerAddr() + "/axis2/services/UserManageService";
    var urlList = [];
    var url = window.location.href;
    urlList = url.split("?");
    var sessionID = urlList[1];
    reqParam.sessionID = sessionID;
    var pl = new SOAPClientParameters();
    var reqParamStr = JSON.stringify(reqParam);
    pl.add("reqParam", reqParamStr);
    SOAPClient.invoke(userManageServiceUrl, "logout", pl, false, callback);
  }

2、问题原因:

logout()中调用SOAPClient.invoke()方法,参数为true,代表前端和server是异步方式通信,即前端还未接收到server端的响应,便已经执行后面的语句了,在该问题中表现为前端执行logout()时还未等到server的响应,便已经将页面关闭了,所以表现为logout()未执行。

3、解决方法:

将前端和server通信方式改为同步,即将SOAPClient.invoke()方法中true改为false,问题得到解决。

Javascript 相关文章推荐
js实现的跟随鼠标移动的时钟效果(中英文日期显示)
Jan 17 Javascript
关于捕获用户何时点击window.onbeforeunload的取消事件
Mar 06 Javascript
让angularjs支持浏览器自动填表
Nov 10 Javascript
jquery处理页面弹出层查询数据等待操作实例
Mar 25 Javascript
详解JavaScript的回调函数
Nov 20 Javascript
基于AngularJs + Bootstrap + AngularStrap相结合实现省市区联动代码
May 30 Javascript
简单实现js菜单栏切换效果
Mar 04 Javascript
利用JavaScript在网页实现八数码启发式A*算法动画效果
Apr 16 Javascript
详解在不使用ssr的情况下解决Vue单页面SEO问题
Nov 08 Javascript
JavaScript实现获取两个排序数组的中位数算法示例
Feb 26 Javascript
Vue3新特性之在Composition API中使用CSS Modules
Jul 13 Javascript
vue实现顶部菜单栏
Nov 08 Javascript
用js通过url传参把数据从一个页面传到另一个页面
Sep 01 #Javascript
用jquery实现动画跳到顶部和底部(这个比较简单)
Sep 01 #Javascript
Javascript让DEDECMS告别手写Tag
Sep 01 #Javascript
通过JS来动态的修改url,实现对url的增删查改
Sep 01 #Javascript
一个不错的仿携程自定义数据下拉选择select
Sep 01 #Javascript
原生javascript实现拖动元素示例代码
Sep 01 #Javascript
使用text方法获取Html元素文本信息示例
Sep 01 #Javascript
You might like
php时间不正确的解决方法
2008/04/09 PHP
PHP对象Object的概念 介绍
2012/06/14 PHP
关于url地址传参数时字符串有回车造成页面脚本赋值失败的解决方法
2013/06/28 PHP
Yii配置与使用memcached缓存的方法
2016/07/13 PHP
thinkPHP js文件中U方法不被解析问题的解决方法
2016/12/05 PHP
php实现头像上传预览功能
2017/04/27 PHP
javascript里的条件判断
2007/02/27 Javascript
List Installed Software Features
2007/06/11 Javascript
javascript Xml增删改查(IE下)操作实现代码
2009/01/30 Javascript
ie和firefox不兼容的解决方法集合
2009/04/28 Javascript
javascript实现textarea中tab键的缩排处理方法
2015/06/26 Javascript
jQuery插件ImageDrawer.js实现动态绘制图片动画(附源码下载)
2016/02/25 Javascript
Jquery判断form表单数据是否变化
2016/03/30 Javascript
angular源码学习第一篇 setupModuleLoader方法
2016/10/20 Javascript
jQuery基于cookie实现换肤功能实例
2017/10/14 jQuery
Vue父子模版传值及组件传值的三种方法
2017/11/27 Javascript
微信小程序 MinUI组件库系列之badge徽章组件示例
2018/08/20 Javascript
在vue中读取本地Json文件的方法
2018/09/06 Javascript
解决使用layui的时候form表单中的select等不能渲染的问题
2019/09/18 Javascript
Vue Cli3 打包配置并自动忽略console.log语句的方法
2020/04/23 Javascript
vue-路由精讲 二级路由和三级路由的作用
2020/08/06 Javascript
vue element和nuxt的使用技巧分享
2021/01/14 Vue.js
Python使用Paramiko模块编写脚本进行远程服务器操作
2016/05/05 Python
Python后台开发Django的教程详解(启动)
2019/04/08 Python
Tensorflow 模型转换 .pb convert to .lite实例
2020/02/12 Python
Python的Tqdm模块实现进度条配置
2021/02/24 Python
详解css position 5种不同的值的用法
2019/07/30 HTML / CSS
利用canvas实现图片压缩的示例代码
2018/07/17 HTML / CSS
机关党建工作汇报材料
2014/08/20 职场文书
工作失职造成投诉的检讨书范文
2014/10/05 职场文书
销售经理工作失职检讨书
2014/10/24 职场文书
2014年纪检监察工作总结
2014/11/11 职场文书
联谊活动总结范文
2015/05/09 职场文书
2016习总书记系列重要讲话心得体会
2016/01/15 职场文书
《正面管教》读后有感:和善而坚定的旅程
2019/12/19 职场文书
win10蓝屏0xc0000001安全模式进不了怎么办?win10出现0xc0000001的解决方法
2022/08/05 数码科技