MVC HttpPost修改模型并替换视图

时间:2012-11-02 19:59:24

标签: asp.net-mvc ajax.beginform

有人可以帮我理解这一点。我有以下代码:

控制器

public ActionResult Stuff(PersonModel model)
{
    model.Address = "Some Address";

    return PartialView("_Registration", model);
}

视图

    @Ajax.BeginForm("Stuff", new AjaxOptions(){ HttpMethod="POST", UpdateTargetId="the_form", InsertionMode=InsertionMode.Replace, OnSuccess="Stuff"  })
{
    <div id="the_form">
        @{Html.RenderPartial("_Registration", new TypeScriptTest.Models.PersonModel());}
    </div>

    <input type="submit" value="Get Addreess" />
}

部分视图

@model TypeScriptTest.Models.PersonModel

<table>
    <tr>
        <td>
            Name: 
        </td>
        <td>
            @Html.TextBoxFor(c => c.Name)
        </td>
    </tr>
    <tr>
        <td>
            Address: 
        </td>
        <td>
             @Html.TextBoxFor(c => c.Address)
        </td>
    </tr>
</table>

使用我在两个字段中输入的内容发布数据。但后来我用“Some Address”替换了Address属性值并返回一个PartialView,我希望得到一个替换旧的视图。这可能会发生,但替换旧的视图不包括新的“Some Address”值。它看起来与我发布的视图完全一样。

我有一个解决方法,但我想了解这里发生了什么。我的解决方法如下:

public ActionResult Stuff(PersonModel model)
{
    model.Address = "Some Address";

    var v = PartialView("_Registration");

    var view = v.ViewEngineCollection.OfType<System.Web.Mvc.RazorViewEngine>().Single().FindPartialView(new ControllerContext(HttpContext, RouteData, this), "_Registration", false);

    var result = new PartialViewResult() { View = view.View };

    result.ViewData.Model = model;

    return result;
}

在这里,我可以使用false作为FindPartialView中的最后一个参数来绕过缓存。将此参数设置为true会导致与讨论中的问题相同的问题。

为什么会发生这种情况以及解决此问题的正确方法是什么?我的解决方法运行正常,但我想了解这个问题。

1 个答案:

答案 0 :(得分:1)

如果您仍然感兴趣,这是因为从表单提交的值存储在ModelState中,并且在呈现HtmlHelpers时,ModelState中的任何值都优先于您当前的模型对象值。

如果要更改用户提交的值,则可以清除modelState或清除要更改的单个属性的条目。 (清除模型状态时要小心,因为这也会清除任何提交值的错误,至少在手动修改之前,您可能希望确保ModelState有效)

我想,通过你的工作,你最终会得到一个没有提交值的干净ModelState。

您可能会发现这个类似问题的答案很有用:Asp.net MVC ModelState.Clear