ASP.NET MVC3 Ajax.ActionLink - 条件确认对话框

时间:2012-03-07 16:03:49

标签: javascript ajax asp.net-mvc

我有一个@ Ajax.ActionLink,只有在满足某些条件(用户有未保存的更改)时才会显示确认对话框。我创建了一个javascript函数,根据需要显示确认对话框,并根据响应返回true或false。我将它绑定到ActionLink的onclick事件,但是错误的结果不会取消操作。以下是我的代码示例:

@Ajax.ActionLink("Done", .. , .. , 
                  new AjaxOptions() { UpdateTargetId = "MyContainerId"},
                  new { onclick = "ConfirmDone()" })

这是javascript函数

function ConfirmDone() {
    //for testing purposes we can always show the dialog box
    return confirm("Are you sure you want to lose unsaved changes?");
}

显示Ajax.ActionLink的条件确认对话框的最佳方法是什么?

1 个答案:

答案 0 :(得分:14)

使用OnBegin事件:

@Ajax.ActionLink("Done", "ActionName", 
    new AjaxOptions 
    { 
        OnBegin = "return ConfirmDone()", 
        UpdateTargetId = "MyContainerId" 
    })

如果你需要做的就是弹出一个确认框,你也可以使用Confirm ajax选项。如果您需要执行更多自定义逻辑(或想要使用自定义对话框),则需要使用OnBegin。

以下是使用确认的示例:

@Ajax.ActionLink("Done", "ActionName", 
    new AjaxOptions 
    { 
        Confirm= "Are you sure you want to do this?", 
        UpdateTargetId = "MyContainerId" 
    })