我有一个模型,它的名称字段被远程验证为唯一值。它按预期工作。现在,如果我想更新一些其他属性而不更改名称字段,在这种情况下,我也会在名称字段上得到验证错误。根据devextreme文档,reevaluate
选项应设置为false,以便不验证值未更改的字段。我相应地配置了验证器,但这没有任何效果。
以下是验证器配置脚本的视图(其他字段通过ASP.net验证属性进行配置(:
@model Sender
<form asp-action=@(ViewBag.Mode == "new" ? "AddSender" : "UpdateSender") asp-controller="Sender" method="post">
@using (Html.DevExtreme().ValidationGroup())
{
@Html.HiddenFor(m => Model.Id)
@(Html.DevExtreme().Form<Sender>()
.ID("form")
.FormData(Model)
.ColCount(1)
.Items(items => {
items.AddSimpleFor(m => Model.Name).Label(l => l.Text("Név")).Editor(e => e.TextBox().ID("sendername")).IsRequired(true);//.Editor(e => e.Autocomplete()
//.DataSource(d => d.StaticJson().Url(Url.Action("GetNames", "Sender")))
//.SearchMode(DropDownSearchMode.StartsWith)
//.ValueExpr("Name"));
items.AddSimpleFor(m => Model.Address);
items.AddSimpleFor(m => Model.ContactPerson);
items.AddSimpleFor(m => Model.ContactEmail);
items.AddGroup().Items(groupItem => groupItem.AddSimple().Template(
@<text>
<div style="text-align: right">
@(Html.DevExtreme().Button().ID("save").Text("Mentés").Width(100).Type(ButtonType.Success).UseSubmitBehavior(true))
@(Html.DevExtreme().Button().ID("cancel").Text("Mégsem").Width(100).Type(ButtonType.Normal).OnClick("close_onClick"))
</div>
</text>));
})
.LabelLocation(FormLabelLocation.Top)
)
}
</form>
<script>
$("#sendername").dxTextBox().dxValidator({
validationRules: [{
type: "async",
message: "Partner with this name already exists",
reevaluate: false,
validationCallback: function (params) {
return DevExpress.aspnet.sendValidationRequest("Name", params.value, "/MasterData/Sender/ValidateSenderName", "POST");
}
}, {
type: "required",
message: "Field value cannot be null"
}
]
});
</script>
我该如何解决这个问题?
我建议为Model的"Name"字段添加Remote
属性,而不是创建验证器。我在你的代码中发现了一个错误,你为"sendername"创建了dxTextBox,但它是之前创建的在剃刀。这篇博客文章描述了在ASP.NET Core和ASP.NET MVC中使用异步验证。