使用“location.href”取消页面卸载时出现“未知异常”

时间:2009-10-02 13:54:04

标签: asp.net javascript onbeforeunload

我正在使用以下代码捕获window.onbeforeunload事件:

window.onbeforeunload = function (evt) 
{

    if(checkIsDirty())
        { 
            var message = 'If you continue your changes will not be saved.'; 
            if (typeof evt == 'undefined') 
            {   
                //IE 
                evt = window.event; 
            } 
            if (evt) 
            { 
                evt.returnValue = message; 
            }
            else
            {
                return message; 
            }
        }

} 

当我在结果确认中单击“取消”时,出现错误“未知异常”,调试器突出显示以下内容:

onclick="location.href='/<WhicheverPageYouRequested>.aspx';

如果单击“确定”,页面将完美更改。为什么我会收到此错误,我该如何解决?

1 个答案:

答案 0 :(得分:9)

是的,这是一种已知的IE行为。当您尝试从JavaScript导航时(使用location,location.href,location.replace,document.location,history,甚至是诸如link.click或form.submit之类的环形交叉方法),beforeunload取消将引发异常。测试用例很简单:

window.onbeforeunload= function() { return '?'; }
location.href= 'http://www.example.com/';

这可能是故意的,让脚本知道导航尝试失败,除了错误名称是如此完全无用。 (我得到“未指定的错误”。)

传统的解决方案就是抓住它:

try {
    location.href= '...';
} catch(e) {}

我总是怀疑这一点虽然抓住所有异常通常都是坏消息(但IE不允许你只捕获这个异常......没有检查确切的stringTo,这是非常脆弱的。

另一种方法是将onbeforeunload工作移动到调用代码,以便真正的onbeforeunload永远不会发生,并且没有异常:

function navigate(url) {
    if (window.onbeforeunload) {
        if (confirm(window.onbeforeunload()+' Press OK to continue, or Cancel to stay on the current page.')
            window.onbeforeunload= '';
        else
            return;
    }
    location.href= url;
}

然而,如果您正在使用的是插入代码的框架,而不是您自己编写的内容,那么任何一种解决方案都可能超出您的掌握范围。

onclick="location.href='/<WhicheverPageYouRequested>.aspx'";
这是什么样的控制?它本身看起来很可疑:当然,你点击进入另一个页面的东西应该被标记为一个简单的链接,而不是一个JavaScript-onclick元素(这些元素在很多方面出错)。如果它是一个简单的非JavaScript链接,您就不必担心IE错误。

顺便提一下,你的beforeunload函数可能会在非IE浏览器上失败(returnValue只是一个IE浏览器)。它似乎有点过于复杂......出了什么问题:

window.onbeforeunload= function() {
    if(checkIsDirty())
        return 'If you continue your changes will not be saved.';
}