当我刚删除编辑器字段时,我不会'希望用户在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,我仍然得到一个空值。
答案 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" } })