MVC 6 VNext 如何设置HtmlFieldPrefix?
MVC 6 VNext how to set HtmlFieldPrefix?
我的观点分为局部观点。因此,在提交时我的模型没有正确重建。
页面视图显示员工数据,其中 Employee.Contactinfo 是 _contactInfo 部分视图的模型,它再次有一个部分视图 _phoneInfo 来呈现 phone 信息具有模型 Employee.ContactInfo.PhoneInfo.
现在问题出在属性名称上。 Employee.ContactInfo.PhoneInfo。渲染时的 Contact1 名称为 "Contact1",因此在提交时未正确创建模型,我得到了 Employee 的原始数据,但像 ContactInfo 这样的复杂类型为空。
我觉得解决方法是在局部视图渲染的时候加上前缀。我如何在 MVC 6 中执行以下操作?
employee.cshtml
@model Employee
<% Html.RenderPartial("_conctactInfo", Model.ContactInfo, new ViewDataDictionary
{
TemplateInfo = new System.Web.Mvc.TemplateInfo { HtmlFieldPrefix = "ContactInfo" }
})
%>
_contactInfo.cshtml
@model ContactInfo
<% Html.RenderPartial("_phoneInfo", Model.PhoneInfo, new ViewDataDictionary
{
TemplateInfo = new System.Web.Mvc.TemplateInfo { HtmlFieldPrefix = "PhoneInfo" }
})
%>
_phoneInfo.cshtml
@model PhoneInfo
<input asp-for="@Model.Contact1" />
这是解决方案,
namespace Website1.Extensions
{
public static class HtmlHelper
{
public static IHtmlContent Partial(this IHtmlHelper htmlHelper, string partialViewName, object model, string prefix)
{
var viewData = new ViewDataDictionary(htmlHelper.ViewData);
var htmlPrefix = viewData.TemplateInfo.HtmlFieldPrefix;
viewData.TemplateInfo.HtmlFieldPrefix += !Equals(htmlPrefix, string.Empty) ? $".{prefix}" : prefix;
return htmlHelper.Partial(partialViewName, model, viewData);
}
public static Task<IHtmlContent> PartialAsync(this IHtmlHelper htmlHelper, string partialViewName, object model, string prefix)
{
var viewData = new ViewDataDictionary(htmlHelper.ViewData);
var htmlPrefix = viewData.TemplateInfo.HtmlFieldPrefix;
viewData.TemplateInfo.HtmlFieldPrefix += !Equals(htmlPrefix, string.Empty) ? $".{prefix}" : prefix;
return htmlHelper.PartialAsync(partialViewName, model, viewData);
}
}
}
employee.cshtml
@using Website1.Extensions;
@model Employee
@Html.Partial("_contactInfo", Model.ContactInfo, nameof(Model.ContactInfo))
_contactInfo.cshtml
@using Website1.Extensions;
@model ContactInfo
@Html.Partial("_phoneInfo", Model.PhoneInfo, nameof(Model.PhoneInfo))
_phoneInfo.cshtml
@model PhoneInfo
<input asp-for="@Model.Contact1" />
如果您只需要一次,这将是 _contactInfo 局部视图的快速解决方案
employee.cshtml
@{
var viewData = new ViewDataDictionary(ViewData);
viewData.TemplateInfo.HtmlFieldPrefix = "ContactInfo";
}
<partial name="_conctactInfo" model="Model.ContactInfo" view-data="@viewData"/>
我的观点分为局部观点。因此,在提交时我的模型没有正确重建。
页面视图显示员工数据,其中 Employee.Contactinfo 是 _contactInfo 部分视图的模型,它再次有一个部分视图 _phoneInfo 来呈现 phone 信息具有模型 Employee.ContactInfo.PhoneInfo.
现在问题出在属性名称上。 Employee.ContactInfo.PhoneInfo。渲染时的 Contact1 名称为 "Contact1",因此在提交时未正确创建模型,我得到了 Employee 的原始数据,但像 ContactInfo 这样的复杂类型为空。
我觉得解决方法是在局部视图渲染的时候加上前缀。我如何在 MVC 6 中执行以下操作?
employee.cshtml
@model Employee
<% Html.RenderPartial("_conctactInfo", Model.ContactInfo, new ViewDataDictionary
{
TemplateInfo = new System.Web.Mvc.TemplateInfo { HtmlFieldPrefix = "ContactInfo" }
})
%>
_contactInfo.cshtml
@model ContactInfo
<% Html.RenderPartial("_phoneInfo", Model.PhoneInfo, new ViewDataDictionary
{
TemplateInfo = new System.Web.Mvc.TemplateInfo { HtmlFieldPrefix = "PhoneInfo" }
})
%>
_phoneInfo.cshtml
@model PhoneInfo
<input asp-for="@Model.Contact1" />
这是解决方案,
namespace Website1.Extensions
{
public static class HtmlHelper
{
public static IHtmlContent Partial(this IHtmlHelper htmlHelper, string partialViewName, object model, string prefix)
{
var viewData = new ViewDataDictionary(htmlHelper.ViewData);
var htmlPrefix = viewData.TemplateInfo.HtmlFieldPrefix;
viewData.TemplateInfo.HtmlFieldPrefix += !Equals(htmlPrefix, string.Empty) ? $".{prefix}" : prefix;
return htmlHelper.Partial(partialViewName, model, viewData);
}
public static Task<IHtmlContent> PartialAsync(this IHtmlHelper htmlHelper, string partialViewName, object model, string prefix)
{
var viewData = new ViewDataDictionary(htmlHelper.ViewData);
var htmlPrefix = viewData.TemplateInfo.HtmlFieldPrefix;
viewData.TemplateInfo.HtmlFieldPrefix += !Equals(htmlPrefix, string.Empty) ? $".{prefix}" : prefix;
return htmlHelper.PartialAsync(partialViewName, model, viewData);
}
}
}
employee.cshtml
@using Website1.Extensions;
@model Employee
@Html.Partial("_contactInfo", Model.ContactInfo, nameof(Model.ContactInfo))
_contactInfo.cshtml
@using Website1.Extensions;
@model ContactInfo
@Html.Partial("_phoneInfo", Model.PhoneInfo, nameof(Model.PhoneInfo))
_phoneInfo.cshtml
@model PhoneInfo
<input asp-for="@Model.Contact1" />
如果您只需要一次,这将是 _contactInfo 局部视图的快速解决方案
employee.cshtml
@{
var viewData = new ViewDataDictionary(ViewData);
viewData.TemplateInfo.HtmlFieldPrefix = "ContactInfo";
}
<partial name="_conctactInfo" model="Model.ContactInfo" view-data="@viewData"/>