Ajax.BeginForm with OnComplete始终更新页面

Ajax.BeginForm with OnComplete始终更新页面,ajax,asp.net-mvc,events,ajaxform,Ajax,Asp.net Mvc,Events,Ajaxform,我在MVC中有简单的ajax表单。在AjaxOptions中,有一个OnComplete设置为simple javascript函数,它只做一件事——返回false @using (Ajax.BeginForm("Action", "Controller", new AjaxOptions { UpdateTargetId = "DivFormId", HttpMethod = "Post", OnComplete = "preventUpdate" })) function preventU

我在MVC中有简单的ajax表单。在AjaxOptions中,有一个OnComplete设置为simple javascript函数,它只做一件事——返回false

@using (Ajax.BeginForm("Action", "Controller", new AjaxOptions { UpdateTargetId = "DivFormId", HttpMethod = "Post", OnComplete = "preventUpdate" }))

function preventUpdate(xhr) {
    return false;       
}
问题是,该页面已经更新。例如,在一种情况下,控制器在回发后返回部分视图,在另一种情况下,它返回一些Json对象。我希望它在返回部分视图时更新页面,并在返回json时显示对话框窗口。不幸的是,当返回json时,即使OnComplete函数返回false,它也会清除页面(使用json更新页面),正如MSDN所说:要取消页面更新,请从JavaScript函数返回false

如何根据收到的响应防止页面更新

谢谢大家!

-----更新-------


到目前为止,我找到了以下解决方案。当我没有指定UpdateTargetId时,我可以手动处理我想要的响应。但是它仍然没有记录返回false的行为。

使用
OnSuccess
并去掉
UpdateTargetId
。像这样:

@using (Ajax.BeginForm("Action", "Controller", new AjaxOptions { HttpMethod = "Post", OnSuccess = "foo" }))
{
    ...
}
然后:

function foo(result) {
    if (result.SomePropertyThatExistsInYourJsonObject) {
        // the server returned a JSON object => show the dialog window here
    } else {
        // the server returned a partial view => update the DOM:
        $('#DivFormId').html(result);
    }
}

也许这会有所帮助,也看看第一条评论,情况并非如此(但可以肯定的是,我也尝试过这两种方法)。这是针对Ajax.BeginForm的MS处理,包括OnBegin、OnComplete等事件,。。。根据MSDN文档,OnComplete应该可以通过返回false来停止