ASP.NET MVC 3 Ajax.BeginForm和Html.TextBoxFor不反映在服务器上完成的更改

时间:2011-11-21 20:17:34

标签: ajax asp.net-mvc-3 razor

我在ASP.NET MVC3中使用Ajax.BeginForm帮助程序提交一个表单,该表单用服务器上设置的表单中的新值替换自己。但是,当我使用Html.TextBoxFor这样的帮助时,我得到了提交的值,而不是我在服务器上插入模型的值。

例如;我在动作中将SomeValue设置为4并将其显示在文本框中。我将值更改为8,点击提交,并期望在文本框中将值更改回4,但由于某种原因,它保持为8.但如果我输出SomeValue而不使用Html帮助程序,则表示4.任何人都有一些关于发生了什么事?

我的控制器:

public ActionResult Index(HomeModel model)
{
    model.SomeValue = 4;
    if (Request.IsAjaxRequest())
        return PartialView(model);
    return View(model);
}
public class HomeModel
{
    public int? SomeValue { get; set; }
}

我的观点(请注意,我的布局页面中没有所有必需的javascript):

<div id="ajaxtest">
@using(Ajax.BeginForm(new AjaxOptions{ InsertionMode = InsertionMode.Replace,
    UpdateTargetId = "ajaxtest", HttpMethod = "Post" })) {
    @Html.TextBoxFor(model => model.SomeValue)
    <input type="submit" value="Update" />
}
</div>

2 个答案:

答案 0 :(得分:6)

你可以使用

ModelState.Clear() 
在您的控制器方法中

使html助手使用您更改的模型。否则,他们使用表单提交

中的值

查看:Asp.net MVC ModelState.Clear

答案 1 :(得分:1)

你需要在你的POST方法中

ModelState.Clear();

反映帖子后所做的更改