我试图避免在 mvc 视图中使用 foreach ,正如我在很多答案中看到的那样,这是一个很好的做法。但我并没有完全了解如何实现它。
我想使用银行列表来创建一堆单选按钮以发布其中一个(实际上是 id)
作为视图模型:
public class CashbackOfferViewModel
{
...
public string DepositBank { get; set; }
public IEnumerable<CompanyBank> DepositBanks { get; set; }
}
我想使用类似的东西:
@Html.EditorFor(m => m.DepositBanks)
这将创建适当的单选按钮。但是在创建编辑器模板时,如果我使用模型
@model CompanyBank
@Html.RadioButtonFor(??????)
@Html.LabelFor(????)
如何将其绑定到模型中的 DepositBank 属性?
更新:
我一直在努力完成这项工作,但在目前的情况下
视图模型:
public class CashbackOfferViewModel
{
....
public string DepositBankCode { get; set; }
public IEnumerable<CompanyBank> DepositBanks { get; set; }
}
编辑器模板;
@model CompanyBank
<tr>
<td>
@Html.RadioButtonFor(m => m.CompanyBankCode, Model.CompanyBankCode)
<span>@Html.LabelFor(m => m.CompanyBankName, Model.CompanyBankName)</span>
</td>
</tr>
但是我在加载时检查了所有单选按钮,实际上生成的 html 就是这个(更改每个按钮的 id)
<input checked="checked" id="DepositBanks_0__CompanyBankCode" name="DepositBanks[0].CompanyBankCode" type="radio" value="HBOS">
基本上我想在视图中使用它:
@Html.EditorFor(m => m.DepositBanks)
而不是这个
@foreach (var depositBank in Model.DepositBanks)
{
@Html.RadioButtonFor(m => m.DepositBankCode , depositBank.CompanyBankCode)
}