私は剣道UIをASP.NET MVCに使用しています。私は列内にいくつかのClientEditorTemplate DropDownListsを持つインライン編集モードの剣道グリッドを持っています。グリッドはモデル "ContractPricingPolicy"のリストにバインドされています。inline編集モードでの剣道検証メッセージ剣道グリッドがデータアノテーションなしで処理されています
public class ContractPricingPolicy
{
//Some other fields
[CustomDisplayName(XmlResourceNames.ContractPricingPoliciesXml, "PricingPolicyType")]
[UIHint("ClientPricingPolicyType")]
[Required(ErrorMessage = "Tο πεδίο {0} είναι υποχρεωτικό")]
public PricingPolicyType PricingPolicyType { get; set; }
//Some other fields
}
あなたは私がEditorTemplateためUIHintを使用して、私は私のフィールドの検証に必要なデータアノテーションを使用見ることができるように。 エディタテンプレートはそのようなものです:
@(Html.AthenaTransportDdl("GetPricingPolicyTypes", "Enterprise", HttpVerbs.Post)
.Name("PricingPolicyType")
.DataTextField("Label")
.DataValueField("Id")
.AutoBind(false)
.Filter("contains")
.HtmlAttributes(new { @class = "atn-flexdisplay-container" })
.OptionLabel(Html.GetResource(AthenaWeb.Models.Common.XmlResourceNames.CommonXml, "PricingPolicyTypeOptionLabel"))
)
私の剣道グリッドはそのようなものです:私は、新しい行を挿入し、価格政策は検証を入力し、選択せずに私の行を保存しよう
@(Html.Kendo().Grid(Model.PricingPolicies)
.Name("pricingPoliciesGrid")
.Columns(columns =>
{
columns.Bound(c => c.Id).Hidden();
columns.Bound(c => c.PricingPolicyType).Width(100)
// Some more columns
columns.Command(command => { command.Edit().Text(" ").UpdateText(" ").CancelText(" "); command.Destroy().Text(" "); }).Width(70)
.HtmlAttributes(new { style = "text-align:center" });
})
.ToolBar(toolbar => toolbar.Template("<div class='col-md-2'><button id='addPPRowBtn' class='btn btn-success' data-atn-mouseover='cStatusDisabled'><span class='fa fa-plus'></span> " + Html.GetResource(gcw, "ToolBarInsertNew") + "</div>"))
.Editable(editable => editable.Mode(GridEditMode.InLine).DisplayDeleteConfirmation(Html.GetResource(cpp, "DeleteConfirmationMsg")))
.DataSource(dataSource => dataSource
.Ajax()
.ServerOperation(true)
.Model(model =>
{
model.Id(c => c.Id);
model.Field(p => p.PricingPolicyType).DefaultValue(new AthenaWeb.Models.Enterprise.PricingPolicyType());
// Some other fields
})
.Create(create => create.Action("PricingPolicy_Create", "Student"))
.Read(read => read.Action("PricingPolicy_Read", "Student", new { id = Model.Id }))
.Destroy(update => update.Action("PricingPolicy_Deactivate", "Student"))
)
)
データ注釈からのデータはトリガーされません。しかし、私はそのように私のエディタのテンプレートに必要な属性を設定した場合:
(Html.AthenaTransportDdl("GetPricingPolicyTypes", "Enterprise", HttpVerbs.Post)
.Name("PricingPolicyType")
.DataTextField("Label")
.DataValueField("Id")
.AutoBind(false)
.Filter("contains")
.HtmlAttributes(new { @class = "atn-flexdisplay-container", required = "required" })
.OptionLabel(Html.GetResource(AthenaWeb.Models.Common.XmlResourceNames.CommonXml, "PricingPolicyTypeOptionLabel"))
)
検証トリガーのが、表示されるメッセージは、私は私のデータ注釈にメッセージを表示する必要がありながら、フィールド{NameOfField}が必要されるデフォルトです。
私の質問は、なぜデータアノテーション検証メッセージを表示できるのか(正確には、エディタテンプレートにバインドされたフィールドの行に対してkendoValidatorをトリガする方法です)
検証はエディタテンプレートを使用して列のために機能するためには