2

使用 MVC3,我发现设置 SelectList 的选定值可以正确地在 HttpGet 上呈现视图,但无法在 HttpPost 上正确呈现。在将模型转发到 HttpPost 上的视图之前,我已经检查了它们并且它们正在正确更新,看来视图没有正确呈现所选标签。

在 HttpPost 上,<select>在任何编辑之后但在提交表单之前呈现完全一样的内容。在m.SelectedWidgetId = 2;HttpPost 方法中执行,更新模型,但不反映在 View 中。

我在这里想念什么?

模型:

public class WidgetModel
{
    private Widget[] Widgets {
        get
        {
            return new Widget[] { 
                new Widget { Id=1, Name="Item 1" },
                new Widget { Id=2, Name="Item 2" },
                new Widget { Id=3, Name="Item 3" }
            };
        }
    }
    public SelectList WidgetList
    {
        get
        {
            return new SelectList(Widgets.ToList(), "Id", "Name", SelectedWidgetId);
        }
    }
    public int SelectedWidgetId { get; set; }
}

看法:

@model thisProject.Models.WidgetModel

@using (Html.BeginForm())
{
    @Html.DropDownListFor(m => m.SelectedWidgetId, Model.WidgetList, "Select...");      
    <input type='submit' />                                                                                    
}

控制器方法;

public ActionResult Widget()
{
    var m = new WidgetModel();
    m.SelectedWidgetId = 1;
    return View(m);
}
[HttpPost]
public ActionResult Widget(WidgetModel m)
{
    m.SelectedWidgetId = 2;
    return View(m);
}
4

2 回答 2

3

发生这种情况是因为 HTML 帮助程序在呈现值时始终使用请求中的值,然后再使用模型中的值。这基本上意味着,如果您想修改 POST 操作中的某些值,您需要首先将其从模型状态中删除:

[HttpPost]
public ActionResult Widget(WidgetModel m)
{
    ModelState.Remove("SelectedWidgetId");
    m.SelectedWidgetId = 2;
    return View(m);
}

或者助手将简单地忽略您手动设置的值并使用用户发布的值。

于 2011-05-05T06:24:32.413 回答
2

在 asp.net mvc 中,selectList 的 selectedvalue 被我们使用强类型帮助器时创建下拉列表的属性的值覆盖,即

<%:Html.DropDownListFor(x=>x.SelectedWidgetID, ---,----)%>

在这种情况下,Model.selectedwidgetID 的值将覆盖在

new SelectList(Widgets.ToList(), "Id", "Name", SelectedWidgetId);
于 2011-05-05T06:23:36.537 回答