asp.net-mvc – Razor中的Direct Model.Property与Html Helper DisplayFor

前端之家收集整理的这篇文章主要介绍了asp.net-mvc – Razor中的Direct Model.Property与Html Helper DisplayFor前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
是否有理由优先使用以下其中一种:
  1. @Model.Property
  2. @Html.DisplayFor(m => m.Property)

我从未到过一个十字路口,一个人的工作方式与另一个不同.

有什么区别?

解决方法

Model.Property – 如您所知 – 将只写出相关属性的值.另一方面,Html.DisplayFor(m => m.Property)将调用显示模板,该模板可以在属性值周围渲染出其他标记.

例如,您可以定义一个显示模板,如下所示:

  1. @model String
  2.  
  3. <div class="property-wrapper">
  4. <p>@Model.Property</p>
  5. </div>

使用DisplayFor时,周围的div将围绕属性的值呈现(如果选择了显示模板,这通常意味着它具有与属性类型匹配的文件名,在属性的UIHint属性中指定,或者在对DisplayFor的调用.

您还可以在显示模板中访问模型元数据,这意味着您可以执行以下操作:

  1. <div class="property-label">
  2. @Html.DisplayNameForModel()
  3. </div>
  4.  
  5. <div class="property-value">
  6. @Model.Property
  7. </div>

显示模板为您提供了极大的灵活性和可重用性.探索此问题的最佳方法是开始构建自定义模板并查看它的使用位置.

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