asp.net-mvc-4 – 复杂模型上的MVC Html.DisplayNameFor

前端之家收集整理的这篇文章主要介绍了asp.net-mvc-4 – 复杂模型上的MVC Html.DisplayNameFor前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我有一个复杂类型的模型,即用户/地址/地址列表
  1. public class User{
  2. public List<Address> Addresses{get;set;}
  3. }

在我的视图中我显示了这个

  1. <fieldset><legend>@Html.DisplayNameFor(model=>model.Addresses)</legend>
  2. <table>
  3. <tr>
  4. <th>
  5. @Html.DisplayNameFor(m => Model.Addresses.Street)
  6. </th>
  7. <th>
  8. @Html.DisplayNameFor(model => model.Addresses.City)
  9. </th>
  10. <th>
  11. @Html.DisplayNameFor(model => model.Addresses.State)
  12. </th>
  13.  
  14. </tr>
  15. @foreach (var item in Model.Addresses) {
  16. <tr>
  17. <td>
  18. @Html.DisplayFor(m => item.Street)
  19. </td>
  20. <td>
  21. @Html.DisplayFor(m => item.City)
  22. </td>
  23. <td>
  24. @Html.DisplayFor(m => item.State)
  25. </td>
  26. </tr>
  27. }
  28. </table></fieldset>

DisplayNameFor Street / City / State不起作用.

在子对象上获取DisplayNameFor的正确方法是什么?

TIA
Ĵ

解决方法

我变了
  1. @Html.DisplayNameFor(m => Model.Addresses.Street)

  1. @Html.DisplayNameFor(m => Model.Addresses.FirstOrDefault().Street)

不要使用@ Html.DisplayNameFor(m => Model.Addresses [0] .Street)因为如果你需要编辑第一行,你将无法这样做.

现在一切都按预期工作了.

猜你在找的asp.Net相关文章