5

我们正在为具有各种形式的应用程序创建警告消息。在简单的页面中这很容易,我们只检测表单元素的变化,如果用户想要卸载页面,我们会向他们显示警告消息。

但是......我们在 Kendo Windows 中也有一些表单,问题是如果用户想要关闭窗口,我们需要显示相同的确认消息。这是我们现在拥有的脚本:

$('div:has(div[data-role="window"])').find('a:has(span.k-i-close)').live('click', function (e) {
    if (formHasChanged) {
        alert('pepe');
        return false;
    }
    return true;
});

该脚本的问题在于它没有阻止窗口关闭,关闭事件似乎发生在我们的警报之前。此解决方案可能有效http: //www.kendoui.c​​om/forums/ui/window/new-event-onclosing.aspx ,但我们的窗口是动态创建的。

有谁知道如何解决这个问题?

提前致谢!

代码是我们想要插入这个剑道东西的解决方法:

var formHasChanged = false;
$('form.withWarningMessage').find('input,select,textarea').live('change', function () {
    formHasChanged = true;
    window.onbeforeunload = function () {
        if (formHasChanged) {
            return confirmWarningMessage;
        }
    };
    $('input:submit').live('click', function () {
        formHasChanged = false;
    });
});
4

2 回答 2

9

即时创建 Windows 并不重要。如果你可以创建它们,那么你可以绑定这样的处理程序。如果 Alex Gyoshev 共享的代码不好。

您最初可以像这样绑定处理程序:

$("#window").kendoWindow({
    close:function(e){
        if (!confirm("are you sure?"))
        e.preventDefault();
    }
})

分享有关您的设置的详细信息,应该有一种方法可以将其中一种方法集成到您的案例中。

于 2013-01-25T20:49:25.800 回答
3

我跑过剑道窗口.Events(events => events.Close("onClose")对我来说根本没有开火的地方。也许是剑道虫子。但是就是说,我使用您发布的链接中的代码解决了这个问题:

$("#myWin").data("kendoWindow").bind("close", function(e) {
    if (!confirm("Are you sure?"))
        e.preventDefault();
}); 

您可以将其视为与您发布的代码完全分开的例程 - 它不会进入那里。如果你真的在动态创建新的 Kendo Windows,你应该给它们所有唯一的、单独的 ID,然后将上面的代码放入一个函数中,传入该 ID 并用传入的动态替换“#myWin” - 生成的 ID,因此每个窗口都会获取bind.

有关剑道 Windows 的更多信息:http: //demos.telerik.com/kendo-ui/window/events

于 2015-03-04T07:55:54.357 回答