我试图弄清楚如何将表单元素绑定到包含数组或可枚举属性的模型。此表单应可用于添加新对象或编辑现有对象。
下面是一个简化的示例。
如果“色阶”不包含任何元素(例如create),则不会呈现“色阶”字段的行。您应该向Level数组添加一个空元素,还是应该添加一行空字段?但是如何使用asp-for属性来做到这一点。
如果“级别”包含元素(例如,编辑),则将显示“级别”字段的行。但是,在model.Levels
方法中发布Edit
时是null
。
有什么想法可以最好地实现吗?
要绑定的模型
public class CarparkModel
{
[HiddenInput]
public int Id { get; set; }
public string Name { get; set; }
public Level[] Levels { get; set; }
}
public class Level
{
[HiddenInput]
public int Id { get; set; }
public string Description { get; set; }
public int NrOfSpaces { get; set; }
}
主视图
@model CarparkModel
<form method="POST">
<input asp-for="Id">
<div>
<label asp-for="Name"></label>
<input asp-for="Name">
</div>
<table>
<tr>
<th>Description</th>
<th>Nr of spaces</th>
</tr>
@foreach (Level level in Model.Levels)
{
<tr>
<td><input asp-for="Description"></td>
<td><input asp-for="NrOfSpaces"></td>
</tr>
}
<tr>
<td colspan="2>
<!-- Click = new row of Level fields added -->
<button type="button">Add level</button>
</td>
</tr>
</table>
<button type="submit">Save</button>
</form>
控制器
public class CarparkController
{
[HttpGet]
public IActionResult Create()
{
return View(new CarparkModel());
}
[HttpPost]
public IActionResult Create(CarparkModel model)
{
if (ModelState.IsValid)
{
_repository.Save(model);
return RedirectToAction("index");
}
return View(model);
}
[HttpGet]
public IActionResult Edit(int id)
{
return View(_repository.Get(id));
}
[HttpPost]
public IActionResult Edit(CarparkModel model)
{
if (ModelState.IsValid)
{
_repository.Save(model);
return RedirectToAction("index");
}
return View(model);
}
}
答案 0 :(得分:1)
如果您希望能够将邮件发送回表格中,请不要使用foreach
。使用for
循环,为项目建立索引命名。
@model CarparkModel
<form method="POST">
<input asp-for="Id">
<div>
<label asp-for="Name"></label>
<input asp-for="Name">
</div>
<table>
<tr>
<th>Description</th>
<th>Nr of spaces</th>
</tr>
@for(var index = 0, index < Model.Levels.Length, index++)
{
<tr>
<td><input asp-for="@Model.Levels[index].Description"></td>
<td><input asp-for="@Model.Levels[index].NrOfSpaces"></td>
</tr>
}
<tr>
<td colspan="2>
<!-- Click = new row of Level fields added -->
<button type="button">Add level</button>
</td>
</tr>
</table>
<button type="submit">Save</button>
</form>
将索引发布到表单时,需要使用索引来重建它。