FluentValidationModelValidatorProvider.Configure(x => x.ValidatorFactory = new NinjectValidatorFactory(_kernel)); AssemblyScanner.FindValidatorsInAssembly(Assembly.GetExecutingAssembly()).ForEach(match => _kernel.Bind(match.InterfaceType).To(match.ValidatorType));
我有一个在整个应用程序中经常使用的局部视图.此局部视图具有自己的视图模型. “main”视图模型(整个视图的视图模型)只是从这个“部分”视图模型继承而来.
public class Indexviewmodel : PersonalInfoviewmodel { ... }
验证器使用相同的模式:
public class IndexValidator : PersonalInfoValidator { ... }
这工作正常,服务器端验证以及“主”视图上的客户端验证工作.但是不会触发部分视图的客户端验证(输入字段上没有data-val- *属性).
我的“主要”视图Index.cshtml
@model Indexviewmodel @Html.TextBoxFor(x => x.SomeProperty) // client-side validation works fine @Html.Partial("PersonalInfo") // client-side validation in the partial view does not work (see below)
我的部分视图PersonalInfo.cshtml:
@model PersonalInfoviewmodel @Html.TextBoxFor(x => x.FirstName) // client-side validation does not work
我注意到当我将局部视图的模型更改为“main”viewmodel时它可以工作:
@model Indexviewmodel @Html.TextBoxFor(x => x.FirstName) // client-side validation works
所以我想在构建客户端验证的某个地方,正确的验证器没有被拾取,并且没有数据-val- *属性被注入到HTML中.但是我无法更改局部视图上的viewmodel,因为它在具有不同“主”视图的几个不同页面上使用(尽管都是从PersonalInfoviewmodel继承).
关于如何在这种情况下使我的客户端验证工作的任何想法?
更新
在挖掘ASP.NET WebStack源几个小时后,我发现问题似乎发生在TextBoxFor方法中.在那里,ModelMetaData是从模型创建的 – 在那里它开始使用Indexviewmodel而不是PersonalInfoviewmodel来获取客户端验证的元数据:
ModelMetadata Metadata = ModelMetadata.FromLambdaExpression(expression,htmlHelper.ViewData); Html.GetUnobtrusiveValidationAttributes("FirstName",Metadata); // no client-side validation attributes found
但是,如果我没有明确指定元数据,则会生成正确的客户端验证属性:
Html.GetUnobtrusiveValidationAttributes("FirstName");
不幸的是,到目前为止,我还没有找到一种方法来利用这些知识.
解决方法
我在渲染输入字段时“手动”注入缺少的data-val- *属性,如下所示:
@Html.TextBoxFor(x => x.FirstName,Html.GetUnobtrusiveValidationAttributes("FirstName"))
由于GetUnobtrusiveValidationAttributes(称为独立)构建正确的HTML属性,我只需将它们添加到TextBox即可.绝对不漂亮,但它有效,我可以继续我的工作.如果有人有更好的解决方案,我会很高兴听到它.