MVC 3编辑器模板似乎不尊重HiddenInput

时间:2012-01-30 17:15:05

标签: asp.net-mvc asp.net-mvc-3 razor html-helper mvc-editor-templates

继Brad Wilson关于using and customizing editor templates的优秀系列之后,我尝试将Object.cshtml添加到Shared\EditorTemplates文件夹中。模板呈现,但模型属性上的[HiddenInput(DisplayValue = false)]不会按预期呈现隐藏的<input type="hidden" ... />。使用[HiddenInput(DisplayValue = true)]按预期呈现隐藏和可见元素。

我已验证Object的默认模板正常工作并呈现隐藏的输入。在基于上面的Brad系列构建自定义模板时,这只是一个问题。

2 个答案:

答案 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>
    }
}