加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > asp.Net > 正文

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

发布时间:2020-12-16 04:13:38 所属栏目:asp.Net 来源:网络整理
导读:是否有理由优先使用以下其中一种: @Model.Property@Html.DisplayFor(m = m.Property) 我从未到过一个十字路口,一个人的工作方式与另一个不同. 有什么区别? 解决方法 Model.Property – 如您所知 – 将只写出相关属性的值.另一方面,Html.DisplayFor(m = m.P
是否有理由优先使用以下其中一种:
@Model.Property
@Html.DisplayFor(m => m.Property)

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

有什么区别?

解决方法

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

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

@model String

<div class="property-wrapper">
    <p>@Model.Property</p>
</div>

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

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

<div class="property-label">
    @Html.DisplayNameForModel()
</div>

<div class="property-value">
    @Model.Property
</div>

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

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读