我想在一组页面上跟踪一组 UI 组件上的鼠标单击事件。为此,我正在使用以下 jquery/ajax 调用(修剪掉 u):
1.Ajax 调用将添加点击记录。
myClickLogger = {
endpoint: '/path/to/my/logging/endpoint.html',
logClickEvent: function(clickCode) {
$.ajax({
'type': 'POST',
'url': this.endpoint,
'async': true,
'cache': false,
'global': false,
'data': {
'clickCode':clickCode
},
'error': function(xhr,status,err){
alert("DEBUG: status"+status+" \nError:"+err);
},
'success': function(data){
if(data.status!=200){
alert("Error occured!");
}
}
});
}
};
2.将调用ajax记录器的JQuery单击事件(clickCode是单击按钮/图像的标识符):
$(document).ready(function() {
$(".myClickEvent[clickName]").click(function() {
var clickCode = $(this).attr("clickName");
myClickLogger.logClickEvent(clickCode);
});
});
每当被跟踪的按钮单击进入新页面时,浏览器都会“取消”上述 ajax 调用(1.)。
如果我将 'aysnc' 更改为 'false',则 ajax 调用成功。
此外,不会进入新页面的点击事件会成功。只有进入新页面的点击事件被取消。
我不想使呼叫同步。
任何想法,可能是什么问题?当点击事件进入新页面时,如何保证之前的异步调用完成?