加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

具有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);
    }
}

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读