ajax - ASP.NET MVC 3 Ajax.BeginForm 和 Html.TextBoxFor 不反射(reflect)在服务器上完成的更改

标签 ajax asp.net-mvc-3 razor

我正在 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 助手使用你改变的模型。否则,他们使用表单提交中的值

看看:Asp.net MVC ModelState.Clear

关于ajax - ASP.NET MVC 3 Ajax.BeginForm 和 Html.TextBoxFor 不反射(reflect)在服务器上完成的更改,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8217985/

相关文章:

php - 将 JQuery 自动完成附加到由 Ajax 调用加载的文本字段

asp.net-mvc-3 - 在 LINQ 查询中调用方法

asp.net-mvc-3 - 我如何将整数列表添加到路由

javascript - AJAX JSON 响应是 'undefined' ?

javascript - 我如何将下拉值传递给ajax Controller ?

java - ajax成功函数出错

c# - MVC3 asp.net 错误 : Value cannot be null. 参数名称:下拉列表中的项目

c# - YouTube Feed解析XML C# Razor

javascript - MVC3 - Javascript 中的动态 URL 重定向

c# - 在 MVC4 分部 View 中使用 PagedList 时的不良行为