有人可以帮我理解这一点。我有以下代码:
控制器
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会导致与讨论中的问题相同的问题。
为什么会发生这种情况以及解决此问题的正确方法是什么?我的解决方法运行正常,但我想了解这个问题。
答案 0 :(得分:1)
如果您仍然感兴趣,这是因为从表单提交的值存储在ModelState中,并且在呈现HtmlHelpers时,ModelState中的任何值都优先于您当前的模型对象值。
如果要更改用户提交的值,则可以清除modelState或清除要更改的单个属性的条目。 (清除模型状态时要小心,因为这也会清除任何提交值的错误,至少在手动修改之前,您可能希望确保ModelState有效)
我想,通过你的工作,你最终会得到一个没有提交值的干净ModelState。
您可能会发现这个类似问题的答案很有用:Asp.net MVC ModelState.Clear