关闭页面时window.location事件未执行的原因分析及解决方案
更新时间:2014年09月01日 09:44:38 投稿:hebedich
最近在做一个项目的时候,遇到个问题,就是关闭页面时window.location事件未执行,百思不得其解,度娘上搜了一下才知道具体原因,记录一下
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,问题得到解决。
您可能感兴趣的文章:
- window.location和document.location的区别分析
- javascript 打开页面window.location和window.open的区别
- window.location.hash 属性使用说明
- 关于js中window.location.href,location.href,parent.location.href,top.location.href的用法与区别
- window.location.hash 使用说明
- window.location.reload()方法刷新页面弹出要再次显示该网页对话框
- window.navigate 与 window.location.href 的使用区别介绍
- window.location不跳转的问题解决方法
相关文章
微信小程序中使用Async-await方法异步请求变为同步请求方法
这篇文章主要介绍了微信小程序中使用Async-await方法异步请求变为同步请求方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2019-03-03js(JavaScript)实现TAB标签切换效果的简单实例
本篇文章主要是对js(JavaScript)实现TAB标签切换效果的简单实例进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助2014-02-02
最新评论