我有问题得到我的复选框进入我的mvc控制器,并将它们保存在数据库中。我在create视图中为每个循环生成一个列表。
我的广告类:
public class Advert
{
public int AdvertId { get; set; }
public int SponsorId { get; set; }
[DisplayName("Amount")]
public int Amount { get; set; }
[DisplayName("Start date")]
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:dd/MM/yy}")]
[DataType(DataType.Date)]
public System.DateTime StartDate { get; set; }
[DisplayName("End date")]
[DataType(DataType.Date)]
[DisplayFormat(ApplyFormatInEditMode = true, DataFormatString = "{0:dd/MM/yy}")]
public DateTime EndDate { get; set; }
public List<Continent> Continents { get; set; }
public List<Country> Countries { get; set; }
public List<Sport> Sports { get; set; }
public Gender Gender { get; set; }
public Sponsor Sponsor { get; set; }
public int SponsorTypeId { get; set; }
}
(part of)创建视图
<div class="editor-label">
@Html.LabelFor(model => model.SponsorId, "Select sport")
</div>
<div class="editor-field">
@foreach (var item in Model.Sports)
{
<tr>
<td>
<input type="checkbox" id="@item.SportId" name="SelectedSport" value="@item.SportId"/>
</td>
<td>
@item.SportName
</td>
</tr> <br />
}
</div>
AdvertController
// POST: /Advert/Create
[HttpPost]
public ActionResult Create(Advert advert)
{
ViewBag.SponsorId = new SelectList(db.Sponsors, "SponsorId", "SponsorCompany", advert.SponsorId);
advert.SponsorTypeId = service.sponsorType(advert.Amount);
if (ModelState.IsValid)
{
db.Adverts.Add(advert);
db.SaveChanges();
return RedirectToAction("Index");
}
return View(advert);
}
我在这一点上真的卡住了一段时间,所以任何帮助都是欢迎的!
如果您只是想获取id,那么最直接的方法是使用命名参数。
<input type="checkbox" id="myParams" name="myParams" value="@item.SportId"/>
然后改变你的定义,按名称拉出列表
public ActionResult Create(Advert advert, string[] myParams)
当您的模型中没有这样的字段时,您如何期望模型绑定器绑定SelectedSport
表单值?您需要将其添加到Advert
类中:
public IEnumerable<String> SelectedSport { get; set; }
然后用所选复选框的值填充。
此外,似乎您正在使用您的数据库实体直接在您的视图。这太糟糕了!您应该创建一个单独的AdvertViewModel
类,并在控制器中填充您需要的值。