標準のMVC3 Razorビューを控えめなJavascript検証で使用しており、@Html.ValidationSummary
を使用してフォームの上部に表示しています。標準の検証([Required]
など)に合格した場合は、ユーザーが[送信]ボタンをクリックしたときに起動する非常にカスタムなクライアント側検証を実行します。 (検証では、いくつかのフォーム要素を調べて、それらの適切なセットがチェックされていることなどを確認します。そのため、単一のフィールドに新しいカスタムバリデーターを作成するだけでは簡単ではありません)。
そこに構築した可能なエラーをValidationSummary
リストに表示したいのですが、そこにエラーメッセージを表示する方法がわかりません。
クライアント側:
function YourCustomValidator() {
// do your validation logic here via JavaScript
return true; // or false based on your validation logic
}
$(document).ready(function () {
// take your own form-selector like ("form", this)
$("form", this).first().submit(function () {
return (YourCustomValidator() && $(this).valid());
});
});
またはサーバー側:
次のようなモデルがあると考えてください:
public class Test {
[Required]
[StringLength(100)]
public string FullName { get; set; }
}
そしてそれを検証しているとき:
if(ModelState.IsValid) { // default validations run here
if(/* some custom validations run here, there is an error about "FullName" */){
// you should set the "key" for Model-Error to "FullName"
ModelState.AddModelError("FullName","error-message goes here")
}
if(/* some custom validations run here, the error is global, not on "FullName" */){
// you should set the "key" for Model-Error to an empty-string
ModelState.AddModelError("","error-message goes here")
}
// also you can test for model-errors again like this:
if(ModelState.IsValid) { // if you add any error above, this will be "false"
}
}
ビューでValidationSummary()
が呼び出されていれば、ModelState
にError Message
を追加するだけでエラーメッセージが表示されます。
エラーをModelState
に追加するには、次のようにします。
ModelState.AddModelError("ColumnNameOrErrorMessageKeyInState","error message goes here")