3

我正在开发一个 asp.net(框架 4),如果他们试图离开页面而不保存更改,则需要通知用户。好吧,我onbeforeunload通过 JavaScript 调用函数找到了解决方案。在 IE 中效果很好,但在 Firefox、Safari 或 Chrome 中效果不佳。

现在这就是问题所在。我正在使用 AJAX 回发,如果在离开页面之前提示用户保存更改,则更新面板内的任何控件都不会再回发到服务器。例如,如果按下更新面板内的保存按钮,则不会发生任何事情。

以下是一些代码片段

javascript:

window.onbeforeunload = function (e) {
    if (doBeforeUnload() == true) {
        var ev = e || window.event;
        // For IE and Firefox prior to version 4
        if (ev) {
            ev.returnValue = "You have modified the data entry fields since the last time it was saved. If you leave this page, " +
                "any changes will be lost. To save these changes, click Cancel to return to the page, and then Save the data.";
        }
        // For Safari
        return "You have modified the data entry fields since the last time it was saved. If you leave this page, " +
                "any changes will be lost. To save these changes, click Cancel to return to the page, and then Save the data.";

    }
}

ASP.NET:

<asp:UpdatePanel ID="UpdatePanel1" runat="server" >
    <ContentTemplate>
        <%--no controls inside of this panel will postback to server if user clicks the “Stay on Page” button--%>
    </ContentTemplate>
</asp:UpdatePanel>

网上好像有很多帖子,但没有解决办法。除了不使用异步回发之外还有什么想法吗?

4

1 回答 1

0

我在搜索类似问题时遇到了这个问题。我能够通过执行以下操作来解决这个问题:

var doOnBeforeUnloadCheck = true;  // global to set in link button
window.onbeforeunload = function (e) {
    if (doOnBeforeUnloadCheck && doBeforeUnload()) {
        // do stuff
    }
    // Make sure to always re-enable check to ensure the event will still trigger
    // where not specified to disable event.
    doOnBeforeUnloadCheck = true;  
}

在 a 中LinkButton,您只需确保在运行任何其他 javascript 或执行回发之前将全局设置为 false:

<asp:LinkButton ID="yourButton" runat="server"
    OnClientClick="doOnBeforeUnloadCheck = false;" OnClick="yourButton_Click" />

我在以下链接的帮助下遇到了这个解决方案:

http://www.jimandkatrin.com/CodeBlog/post/LinkBut​​ton-UpdatePanel-onbeforeunload.aspx

我在找到答案之前就找到了这个问题,所以如果其他人有同样的问题,这可能会为他们节省一些时间。希望有帮助。

于 2013-01-17T21:04:44.560 回答