为什么在POST操作中DropDown值为Null?

时间:2013-01-16 19:31:20

标签: asp.net-mvc http-post html.dropdownlistfor

以下是视图:

<%@ Page Title="" Language="C#" 
         MasterPageFile="~/Views/Shared/Site.Master" 
         Inherits="System.Web.Mvc.ViewPage<MvcApplication1.Models.Index>" %>

<asp:Content ID="Content1" ContentPlaceHolderID="TitleContent" runat="server">
    Contact
</asp:Content>
<asp:Content ID="Content2" ContentPlaceHolderID="MainContent" runat="server">
    <% using (Html.BeginForm())
    {%>
         <%=Html.DropDownListFor(x => x.SelectedFavColor, Model.DropDownItems)%>
         <%= Html.ValidationMessageFor(x=> x.SelectedFavColor) %>
         <input type="submit" value="submit" />
    <%} %>
</asp:Content>

下面提到的是模型:

namespace MvcApplication1.Models
{
    public class Index
    {
        [Range(0, 1000, ErrorMessage = "hello")]
        public int SelectedFavColor { get; set; }

        public IEnumerable<SelectListItem> DropDownItems { get; set; }
    }

    public class Colors
    {
        public int ColorID { get; set; }
        public string ColorName { get; set; }
    }
}

我在视图中传递了一些Dropdown值。 以下是Controller操作:

public ActionResult Contact()
{
    List<MvcApplication1.Models.Colors> l = new List<Models.Colors>();
    l.Add(new Models.Colors { ColorName = "-1", ColorID = -1 });
    l.Add(new Models.Colors { ColorName = "a", ColorID = 0 });
    l.Add(new Models.Colors { ColorName = "b", ColorID = 2 });
    l.Add(new Models.Colors { ColorName = "c", ColorID = 3 });
    l.Add(new Models.Colors { ColorName = "d", ColorID = 4 });
    l.Add(new Models.Colors { ColorName = "e", ColorID = 4 });
    l.Add(new Models.Colors { ColorName = "f", ColorID = 4 });

    var model = new MvcApplication1.Models.Index
    {
        DropDownItems = l.Select(i => new SelectListItem 
                { 
                      Text = i.ColorName, 
                      Value = i.ColorID.ToString() 
                })
    };
    ViewData["records"] = model.DropDownItems;
    return View(model);
}

[HttpPost]
public ActionResult Contact(Index posted, FormCollection collection)
{
    posted.SelectedFavColor = Convert.ToInt16(collection["SelectedFavColor"]);
    return View(posted);
}

为什么在POST操作中DropDown值为Null?

2 个答案:

答案 0 :(得分:0)

DropDownItemsnull,因为您的表单中没有POST。您只需创建一个下拉菜单:Html.DropDownListFor(x => x.SelectedFavColor, Model.DropDownItems),这不足以发布该集合。

然而,发布一个集合相当棘手;但你可以查看this

最后一件事:你已经有了这个集合(因为你将它传递给View),所以从技术上讲,你甚至不需要POST它回到服务器。

答案 1 :(得分:0)

DropDown值为null的简单原因是因为它们没有使用表单发送(POST)(您可以使用Firebug Firefox扩展程序轻松检查它)。您需要再次收集(重新填充)下拉列表的值以查看视图中的这些值。

建议:

POST后不要立即返回视图。 ASP-MVC应用程序中的典型模式是Post-Redirect-Get。它将帮助您避免表单的不必要的重新POST(例如,在浏览器刷新按钮上) - Why should I use PRG