mailto link (in chrome) is triggering [removed] - can i prevent this?

后端 未结 7 1325
鱼传尺愫
鱼传尺愫 2021-02-18 19:09

Possibly related to How to open mailto link in Chrome with Window.open without creating a new tab?

Hi all. I have a form page where i\'ve put a window.onbeforeunload co

相关标签:
7条回答
  • 2021-02-18 19:20

    I managed to solve this problem inside the onbeforeunload event by checking event.target. This way you dont have to use outer variables or any extra bindings.

    window.onbeforeunload = function (event) {
    
        var activeElement = $(event.target.activeElement);
        // console.log('onbeforeunload', activeElement);
    
        var isMailto = activeElement && activeElement.is('[href^=mailto:]');
        var isTel = activeElement && activeElement.is('[href^=tel:]');
    
        if(!isMailto && !isTel) {
            // logic when link is "normal"
        }
    };
    
    0 讨论(0)
  • 2021-02-18 19:26

    Some other solution with pure JS and using the focused element:

    window.addEventListener("beforeunload", () => {
      const isMailTo = document.activeElement.protocol === "mailto:";
    
      if (!isMailTo) {
        // do your stuff
      }
    });
    
    0 讨论(0)
  • 2021-02-18 19:29

    A really simple fix to this is to do something like this:

    <a href="mailto:foo@bar.com" target="hidden-iframe">Email me</a>
    <iframe name="hidden-iframe" style="visibility:hidden;position:absolute;"></iframe>
    

    (And of course, move the styles to their own stylesheet instead of inlining them.)

    0 讨论(0)
  • 2021-02-18 19:32

    Another option, also a bit hacky but a bit more generic way to make the beforeunload ignore certain types of links:

    In the beforeunload, inspect the link that caused the beforeunload, and if it is not a http or https link, don't bother the user.

    Unfortunately it is not easy to inspect the link that caused the beforeunload, so this is where it gets a little hacky with an onclick handler and global variable.

    var lastClicked = null;
    window.onclick = function(e){
        e = e || window.event;
        lastClicked = e.target
    }
    window.onbeforeunload = function(e){
        if (changed && lastClicked && lastClicked.href 
            && lastClicked.href.substring(0,4) == 'http')
            return "You have unsaved changes";
    }
    

    Edit: Almost forgot, this answer comes from here: https://stackoverflow.com/a/12065766/421243

    0 讨论(0)
  • 2021-02-18 19:36

    Building off of epascarello's solution, the following JQuery code should do the trick:

        var ignore_onbeforeunload = false;
        $('a[href^=mailto]').on('click',function(){
            ignore_onbeforeunload = true;
        });
    
        window.onbeforeunload = function() {
            if (!ignore_onbeforeunload){
                return "Halt! you are not supposed to leave!";
            }
            ignore_onbeforeunload = false;
        };
    
    0 讨论(0)
  • 2021-02-18 19:39

    Based on John Kurlak answer, you can simply use :

    <a href="mailto:foo@bar.com" target="_blank">Email me</a>
    
    0 讨论(0)
提交回复
热议问题