如何让@ Html.Editor为隐形?

时间:2014-11-10 11:26:31

标签: asp.net-mvc

当我刚删除编辑器字段时,我不会'希望用户在View中查看,他们的数据变为空,我想保留数据,但是,我不希望用户编辑它。

  <div class="editor-label">
                @Html.LabelFor(model => model.Name)
            </div>
            <div class="editor-field">
                @Html.EditorFor(model => model.Name)
                @Html.ValidationMessageFor(model => model.Name)
            </div>


            <div class="editor-label">
                @Html.LabelFor(model => model.parent_directory)
            </div>
            <div class="editor-field">
                @Html.DisplayFor(model => model.parent_directory)
            </div>

            <p>
                <input type="submit" value="Add" />
            </p>

我指的是@ Html.EditorFor是model.parent_directory。任何人都可以建议一个不涉及js的解决方案吗?我尝试使用DisplayFor而不是EditorFor,我仍然得到一个空值。

4 个答案:

答案 0 :(得分:14)

请查看此MSDN页面。 http://msdn.microsoft.com/en-us/library/system.web.mvc.html.editorextensions.editorfor(v=vs.118).aspx

根据该页面,出于显而易见的原因,您无法提供html属性作为参数。因为EditorFor可以是input字段或select,并且它们的html属性彼此不同。

如果您只想暂时隐藏它并稍后向用户显示,则可以使用@Html.TextBoxFor。您可以在http://msdn.microsoft.com/en-us/library/system.web.mvc.html.inputextensions.textboxfor(v=vs.118).aspx

找到有关TextBoxFor重载的更多信息

e.g:

@Html.TextBoxFor(model => model.Name, new {style = 'display:none'})

如果您想在整个过程中隐藏这些详细信息,可以使用@Html.HiddenFor

e.g

@Html.HiddenFor(model => model.Name)

答案 1 :(得分:7)

使用隐藏字段:

@Html.HiddenFor(model => model.Name)

答案 2 :(得分:1)

如果您想显示字段并且不允许用户进行编辑,您可以将其设为只读..

@Html.EditorFor(model => model.Name, new {@readonly = "readonly" })

如果您不想向用户显示字段,只需要保存数据就可以使用

@Html.HiddenFor(model => model.Name)

答案 3 :(得分:1)

你可以这样做:

@Html.Editor("WContractID", new { htmlAttributes = new { @class = "form-control", @style = "display: none" } })