概述
慕姐4208626
这与较新版本的Chrome有关。就像@Garry English 所说的那样,async在页面期间发送请求onunload将不起作用,因为浏览器会在发送请求之前终止线程。发送sync请求应该可以。在Chrome版本29之前一直如此,但是在Chrome V 30上,它突然停止工作,如此处所述。看来今天这样做的唯一方法是使用此处建议的onbeforeunload事件。但是请注意:其他浏览器根本不允许您在onbeforeunload事件中发送Ajax请求。因此,您需要做的是在卸载和beforeunload中都执行该操作,并检查它是否已经发生。像这样:var _wasPageCleanedUp = false;function pageCleanup(){ if (!_wasPageCleanedUp) { $.ajax({ type: 'GET', async: false, url: 'SomeUrl.com/PageCleanup?id=123', success: function () { _wasPageCleanedUp = true; } }); }}$(window).on('beforeunload', function (){ //this will work only for Chrome pageCleanup();});$(window).on("unload", function (){ //this will work for other browsers pageCleanup();});
最后
以上就是朴实大侠为你收集整理的chrome jquery ajax请求,在Chrome中window.onbeforeunload ajax请求的全部内容,希望文章能够帮你解决chrome jquery ajax请求,在Chrome中window.onbeforeunload ajax请求所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
发表评论 取消回复