具有OnComplete的Ajax.BeginForm始终更新页面
发布时间:2020-12-16 03:08:14 所属栏目:百科 来源:网络整理
导读:我在MVC中有简单的ajax形式.在AjaxOptions中,OnComplete设置为简单的javascript函数,它只做一件事 – 返回false. @using (Ajax.BeginForm("Action","Controller",new AjaxOptions { UpdateTargetId = "DivFormId",HttpMethod = "Post",OnComplete = "prevent
我在MVC中有简单的ajax形式.在AjaxOptions中,OnComplete设置为简单的javascript函数,它只做一件事 – 返回false.
@using (Ajax.BeginForm("Action","Controller",new AjaxOptions { UpdateTargetId = "DivFormId",HttpMethod = "Post",OnComplete = "preventUpdate" })) function preventUpdate(xhr) { return false; } 问题是,该页面已经更新.例如.在一个案例中,控制器在回发后返回局部视图,在其他情况下,它返回一些Json对象.我希望它在返回部分视图时更新页面,并在返回json时显示对话框窗口.不幸的是,当返回json时,它会清除页面(使用json更新它),即使OnComplete函数返回false,因为MSDN说:要取消页面更新,请从JavaScript函数返回false. 如何根据收到的响应阻止页面更新? 谢谢! —–更新——- 到目前为止,我找到了以下解当我没有指定UpdateTargetId时,我可以手动执行我想要的响应.但是仍然没有记录返回false的行为.
使用OnSuccess并删除UpdateTargetId.喜欢这个:
@using (Ajax.BeginForm("Action",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); } } (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |