继Brad Wilson关于using and customizing editor templates的优秀系列之后,我尝试将Object.cshtml添加到Shared\EditorTemplates
文件夹中。模板呈现,但模型属性上的[HiddenInput(DisplayValue = false)]
不会按预期呈现隐藏的<input type="hidden" ... />
。使用[HiddenInput(DisplayValue = true)]
按预期呈现隐藏和可见元素。
我已验证Object
的默认模板正常工作并呈现隐藏的输入。在基于上面的Brad系列构建自定义模板时,这只是一个问题。
答案 0 :(得分:1)
看起来有些事情发生了变化。检查MVC 3源代码,我发现prop.HideSurroundingHtml
用于确定何时打印周围的HTML,而不是仅打印隐藏的元素。以下模板允许多个级别呈现对象图的编辑器:
@if (ViewData.TemplateInfo.TemplateDepth > 2)
{
@(ViewData.ModelMetadata.Model != null ?
ViewData.ModelMetadata.SimpleDisplayText :
ViewData.ModelMetadata.NullDisplayText)
}
else
{
foreach (var prop in ViewData.ModelMetadata.Properties.Where(pm => pm.ShowForEdit && !ViewData.TemplateInfo.Visited(pm)))
{
if (!prop.HideSurroundingHtml)
{
if (!String.IsNullOrEmpty(Html.Label(prop.PropertyName).ToHtmlString()))
{
<div class="editor-label">@Html.Label(prop.PropertyName)</div>
}
@Html.Raw("<div class=\"editor-field\">")
}
@Html.Editor(prop.PropertyName)
if (!prop.HideSurroundingHtml)
{
@Html.ValidationMessage(prop.PropertyName, "*")
@Html.Raw("</div>")
}
}
}
答案 1 :(得分:0)
我为那些关心的人整理了我的版本:
@foreach (var modelMetadata in ViewData.ModelMetadata.Properties)
{
if (modelMetadata.HideSurroundingHtml == false)
{
if (!string.IsNullOrEmpty(Html.Label(modelMetadata.PropertyName).ToHtmlString()))
{
<div class="editor-label">
@Html.Label(modelMetadata.PropertyName)
</div>
}
<div class="editor-field">
@Html.Editor(modelMetadata.PropertyName)
</div>
}
}