Situation
We have a situation, where we need to onclick-open a new tab in browsers after performing an XHR / Ajax request.
We do this by setting the Ajax request to be performed synchronously to keep the context of the trusted click event and this works fine.
Problem
However, in the latest Chrome version (36), we experience popup warnings when the Ajax call has some lag... A lag of 2 seconds is enough for Chrome to display a popup warning instead of opening the tab like it is supposed to. The code itself is working, I can click that button multiple times and it works all the time until the request experiences some lag. Then I get the popup warning...
Question
Is there a timeout applied to synchronous Ajax requests during which it needs to be finished for the trusted event to still be available?
Is there any way to circumvent that? After all, the call is already synchronous and freezing everything else until the result arrives.
Thanks.
Update JSFiddle
Update: I've created a JSFiddle to demonstrate the problem: http://jsfiddle.net/23JNw/9/
/**
* This method will give open the popup without a warning.
*/
function performSlowSyncronousRequest() {
$.ajax({
url: '/echo/html',
data: {delay: 2}, //JSfiddle will delay the answer by 2 seconds
success: function(){
window.open('http://www.thirtykingdoms.com'); //this causes the popup warning in Chrome
},
async: false
});
}