Skip to main content
 首页 » 编程设计

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

2024年04月30日29qlqwjy

我正在 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