开发者

jQuery: click handler is not invoked when link is opened in new tab/window

开发者 https://www.devze.com 2022-12-25 11:53 出处:网络
I have noticed when user clicks on a link with, say middle button, or shift/ctrl+left button, click handler attach开发者_Python百科ed to hyperlink is not called.

I have noticed when user clicks on a link with, say middle button, or shift/ctrl+left button, click handler attach开发者_Python百科ed to hyperlink is not called.

I have seen solutions to track mousedown event, but what I'd like is to track exact event of following a link.

Are there any suggestions? Thanks


mousedown/mouseup is indeed the only way you can get notified of middle button interaction, so detecting a down-then-up event without intervening mouseout event is more or less the best you can do. It's not very good.

I wouldn't bother, since even if you trapped this one eventuality, there are many other interactions you can't pick up. As well as middle-click (which might not be ‘Open in new tab’ in all browser/configurations; for example in IE6 that'll be the user turning on scrolling mode), the user might right-click and ‘Open in new window’, or drag the link to the address bar or new tab, or various other browser-specific actions to perform a navigation.


If the link is on your site then track it when the page loads instead of on the page where they get the link. If the link is to another site you need to use a redirect URL so your site can track it (example: http://yoursite.com/redirect.html?redirect=http://othersite.com).

In the redirect page you might do something like this (if you want to use JavaScript):

$(document).ready(function(){
  //insert your tracking code here...

  var redirect = getParameterByName('redirect');
  if(redirect != ''){
    window.location = redirect;
  }
});

// From https://stackoverflow.com/questions/901115/how-can-i-get-query-string-values-in-javascript/901144#901144
function getParameterByName( name ){
    name = name.replace(/[\[]/,"\\\[").replace(/[\]]/,"\\\]");
    var regexS = "[\\?&]"+name+"=([^&#]*)";
    var regex = new RegExp( regexS );
    var results = regex.exec( window.location.href );
    if( results == null )
    return "";
    else
    return results[1];
}


you can use 'mousedown' 'mouseup' events in combination with "event.which".

example: http://jsbin.com/ikahe/edit


How to do click hijack right... or rather left.

https://web.archive.org/web/20160305021055/http://mislav.net/2011/03/click-hijack/

0

精彩评论

暂无评论...
验证码 换一张
取 消

关注公众号