当我在表单中使用Html.EditorFor帮助程序时,我希望能够自定义标记的外观,因此我定义了一个EditorTemplate才能做到这一点。这就是我的表单在我看来的样子:
@model Models.SimpleUserClass
@{
ViewBag.Title = "Create User";
}
<div class="row">
<div class="col-lg-6" id="FromPlaceHoler">
@using (Html.BeginForm("CreateUser", "Users"))
{
<fieldset>
<legend>Create One Way Trip</legend>
<div class="editor-label">
@Html.LabelFor(model => model.UserName)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.UserName)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.UserSurname)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.UserSurname)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.UserAge)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.UserAge)
</div>
<div class="editor-label">
@Html.LabelFor(model => model.UserGender)
</div>
<div class="editor-field">
@Html.EditorFor(model => model.UserGender)
</div>
<p>
<input type="submit" value="Create" />
</p>
</fieldset>
}
</div>
</div>
UserName和Surname之类的属性是String类型,因此在我的Shared文件夹中,我创建了EditorTemplates文件夹并创建了一个String.cshtml文件来定义String的编辑器的外观。当运行表单的测试时,它似乎运行良好,因为生成的输入字段具有我指定的外观 - 问题是当我使用这些自定义输入字段提交表单时,mvc无法将我的表单字段映射到我的模型。原因是标签需要支持这种与模型绑定的属性。以下是一个例子:
这是我在String.cshtml EditorTemplate中的代码:
<input type="text" class="form-control">
并且在没有自定义的情况下使用默认的EditorFor时,它会生成以下标记:
<input data-val="true" data-val-required="The User Name field is required." id="UserName" name="UserName" type="text" value="" />
正如我们上面所看到的,我的代码没有'id'和'name'属性,这些属性与我的类中的属性名称相关,并且用于将值绑定到我的类。那么如何更改String.cshtml中的代码以包含这些属性并动态设置它们的值?因为它应该用于我班上的各种属性吗?
答案 0 :(得分:4)
您可以使用:
@model string
@Html.TextBox("", ViewData.TemplateInfo.FormattedModelValue,
new
{
@class = "form-control",
placeholder = ViewData.ModelMetadata.Watermark
?? ViewData.ModelMetadata.DisplayName
?? ViewData.ModelMetadata.PropertyName
})
如果您不想要,请移除占位符。
Re:占位符,这是用户可以在输入中输入的内容的提示。您可以使用注释来装饰模型属性:
[Display(Name = "Client")]
public int ClientId { get; set; }
[Display(Prompt = "Please enter mailing Name")]
public string MailingName { get; set; }
如果你使用这样的东西,你的输入将有占位符属性,其值取自这些注释,按照编辑器模板中指定的顺序(提示(水印),名称,然后是属性的名称)。
答案 1 :(得分:0)
不要使用EditorTemplate for String,只需使用TextBoxFor,如下所示:
@Html.TextBoxFor(model => model.UserName, new { @class = "form-control" })
顺便说一下,为String类型创建EditorTemplate不是一个好主意。 String类型太笼统了。您可能希望对String类型的不同字段使用不同的EditorTemplates。