2

我试图避免在 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)
}
4

1 回答 1

1

您只需要引用要绑定的属性名称

@model CompanyBank


@Html.RadioButtonFor(x => x.PropertyName)
@Html.LabelFor(x => x.PropertyName)

确保将视图命名为 CompanyBank.cshtml,因为在 IEnumerable 中您无法定义编辑器视图名称。

于 2013-10-10T13:20:02.653 回答