我有一个创建页面并有下拉列表。我的问题是,当我提交表单时,下拉列表为空。请帮忙。这是我的代码。
班级
public class Product
{
public int Id { get; set; }
public string Name { get; set; }
public string Description { get; set; }
public List<SelectListItem> Types { get; set; }
}
创建(获取)
// GET: /Products/Create
public ActionResult Create(string id)
{
List<Product> products;
if (Session["products"] != null) products = Session["products"] as List<Product>;
else products = new List<Product>();
var product = products.FirstOrDefault(x => id != null && x.Id == int.Parse(id))??new Product();
var types = new List<SelectListItem>();
var type = new SelectListItem { Selected = false, Value = "0", Text = "Electronics" };
types.Add(type);
type = new SelectListItem { Selected = false, Value = "1", Text = "Non-Electronics" };
types.Add(type);
product.Types = types.Select(x => new SelectListItem { Value = x.Value, Text = x.Text }).ToList();
return View(product);
}
看法
@model MVCViewState.Models.Product
@{
ViewBag.Title = "Create";
}
<h2>Create</h2>
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
@using (Html.BeginForm()) {
@Html.ValidationSummary(true)
<fieldset>
<legend>Product</legend>
<div class="editor-label">
@Html.LabelFor(model => model.Name)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Name)
@Html.ValidationMessageFor(model => model.Name)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Description)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.Description)
@Html.ValidationMessageFor(model => model.Description)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.Types)
</div>
<div class="editor-field">
@Html.DropDownListFor(model => model.Types, Model.Types)
@Html.ValidationMessageFor(model => model.Types)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
<div>
@Html.ActionLink("Back to List", "Index")
</div>
创建(发布)