当模型状态在回发时有效时,文本框将恢复为旧值

时间:2011-01-06 13:41:52

标签: asp.net-mvc-2 binding

也许我错过了一些东西但是当我有一个回复相同动作的表单时,文本框值会恢复为旧值。以下示例应在每个POST的文本框中增加值。这不会发生,模型上的值会增加,模型也会有效。

如果我清除了HttpPost Action中的模型状态(代码中的注释),一切都按预期工作。

我错过了什么吗?

以下是代码:

型号:

public class MyModel
{
    public int MyData { get; set; }
}

查看:

<%@ Page Title="" Language="C#" MasterPageFile="~/Views/Shared/Site.Master" 
Inherits="System.Web.Mvc.ViewPage<MvcApplication1.Models.MyModel>" %>

<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
<% using (Html.BeginForm()) {%>
    <%: Html.TextBoxFor(m => m.MyData)%>   (<%: Model.MyData%>)
                  <%: Html.ValidationMessageFor(m => m.MyData) %> <br />
    State :<%: ViewData["State"] %> <br />
    <input type="submit" />
<% } %>
</asp:Content>

控制器:

public class HomeController : Controller
{
    [HttpGet]
    public ActionResult Index()
    {
        return View(new MyModel { MyData = 0 });
    }

    [HttpPost]
    public ActionResult Index(MyModel myModel)
    {
        // ModelState.Clear();
        ViewData["State"] = "invalid";
        if (ModelState.IsValid)
            ViewData["State"] = "Valid";

        var model = new MyModel { MyData = myModel.MyData + 1 };
        return View(model);
    }

}

2 个答案:

答案 0 :(得分:8)

我刚刚在网上找到了答案。

诀窍是在返回Model

之前清除ModelState
[HttpPost]
public ActionResult Index(MyModel myModel)
{
    // ModelState.Clear();
    ViewData["State"] = "invalid";
    if (ModelState.IsValid)
        ViewData["State"] = "Valid";

    var model = new MyModel { MyData = myModel.MyData + 1 };

    ModelState.Clear();

    return View(model);
}

有关详细信息,请阅读这两篇文章

http://forums.asp.net/p/1527149/3687407.aspx

Asp.net MVC ModelState.Clear

答案 1 :(得分:2)

您应该使用Post-Redirect-Get pattern或不使用Html助手。

参考:http://blogs.msdn.com/b/simonince/archive/2010/05/05/asp-net-mvc-s-html-helpers-render-the-wrong-value.aspx

基本上,MVC希望来自帖子的任何重新显示都是验证错误,并重新使用发布的数据(查看ModelState)进行重新显示,而不是模型数据。该指南是使用ModelState.Clear()