Ajax.BeginForm with OnComplete始终更新页面
我在MVC中有简单的ajax表单。在AjaxOptions中,有一个OnComplete设置为simple javascript函数,它只做一件事——返回falseAjax.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
@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来停止