我正在 ASP.NET MVC3 中使用 Ajax.BeginForm 帮助程序来提交一个表单,该表单将自身替换为服务器上表单集中的新值。但是,当我使用 Html.TextBoxFor 之类的帮助程序时,我得到的是提交的值,而不是我插入到服务器上的模型中的值。
例如;我在操作中将 SomeValue 设置为 4 并将其显示在文本框中。我将值更改为 8,点击提交,并希望文本框中的值更改回 4,但由于某种原因它仍然是 8。但是如果我在不使用 Html 帮助程序的情况下输出 SomeValue,它会显示 4。任何人都知道一些关于这是怎么回事?
我的 Controller :
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; }
}
我的 View (请注意,我的布局页面中有所有需要的 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>
最佳答案
你可以使用
ModelState.Clear()
在你的 Controller 方法中让 html 助手使用你改变的模型。否则,他们使用表单提交中的值
关于ajax - ASP.NET MVC 3 Ajax.BeginForm 和 Html.TextBoxFor 不反射(reflect)在服务器上完成的更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8217985/