1

ValidationSummaryコントロールに一意のエラー メッセージのみを表示させるにはどうすればよいですか?

CRUD 操作を行うために を使用しており、一部のフィールドにはRepeater検証コントロール ( 内) を使用しています。ItemTemplateたとえば、RequiredFieldValidator名/姓の列の場合は a です。Text="*"検証が失敗した場所を簡単に見つけられるように、バリデーターを設定しました。ValidationSummary少なくとも 1 つのバリデーターが失敗した列ごとに 1 つのエラー メッセージが表示されます。

問題はValidationSummary、検証が失敗した行ごとに同じメッセージが表示されることです (これは予想される動作ですが、重複したエラー メッセージを削除できると便利です)。

例: 2 つの行があり、データが入力されていないとします。

お名前必須

お名前必須

姓が必要です

姓が必要です

望ましい動作の代わりに:

お名前必須

姓が必要です

私が見つけた解決策の 1 つは、各列の外側でCustomValidatorを使用し、それらを同じ場所に配置することですが、より良い解決策が必要だと考えています。RepeaterValidationGroupValidationSummary

4

1 に答える 1

0

また、重複したメッセージが表示され、次のjavascriptソリューションが有効であることがわかりました。

Javascript:

<script language="javascript" type="text/javascript">

function RemoveValidationDuplicates(validationGroup) {
    Page_ClientValidate(validationGroup);

    if (typeof (Page_ValidationSummaries) == "undefined")
        return;
    var summary, sums, s;
    for (sums = 0; sums < Page_ValidationSummaries.length; sums++) {
        summary = Page_ValidationSummaries[sums];
        summary.style.display = "none";
        if (!Page_IsValid) {

            if (summary.showsummary != "False") {
                summary.style.display = "";
                if (typeof (summary.displaymode) != "string") {
                    summary.displaymode = "BulletList";
                }
                switch (summary.displaymode) {
                    case "List":
                        headerSep = "<br/>";
                        first = "";
                        pre = "";
                        post = "<br/>";
                        final = "";
                        break;
                    case "BulletList":
                    default:
                        headerSep = "";
                        first = "<ul>";
                        pre = "<li>";
                        post = "</li>";
                        final = "</ul>";
                        break;
                    case "SingleParagraph":
                        headerSep = " ";
                        first = "";
                        pre = "";
                        post = " ";
                        final = "<br/>";
                        break;
                }
                s = "";
                if (typeof (summary.headertext) == "string") {
                    s += summary.headertext + headerSep;
                }
                s += first;

                for (i = 0; i < Page_Validators.length; i++) {
                    if (!Page_Validators[i].isvalid && typeof (Page_Validators[i].errormessage) == "string") {
                        var tempstr = pre + Page_Validators[i].errormessage + post;
                        var isExist = s.search(tempstr);
                        if (isExist == -1)
                            s += pre + Page_Validators[i].errormessage + post;
                    }
                }
                s += final;
                summary.innerHTML = s;
                window.scrollTo(0, 0);
            }
        }
    }
}    
</script>

サマリーとバリデーターは、送信ボタンのOnClientClickが起動されたときにRemoveValidationDuplicatesを呼び出すための入力として機能するValidationGroupを共有します。

<div>
    <asp:ValidationSummary ID="ValidationSummary1" runat="server" ValidationGroup="validationGroupName"/>
    <asp:TextBox ID="TextBox1" runat="server"></asp:TextBox>
    <asp:RequiredFieldValidator ControlToValidate="TextBox1" ID="RequiredFieldValidator1" runat="server" ErrorMessage="RequiredFieldValidator" ValidationGroup="validationGroupName"></asp:RequiredFieldValidator>
    <br/>
    <asp:TextBox ID="TextBox2" runat="server"></asp:TextBox>
    <asp:RequiredFieldValidator ControlToValidate="TextBox2" ID="RequiredFieldValidator2" runat="server" ErrorMessage="RequiredFieldValidator" ValidationGroup="validationGroupName"></asp:RequiredFieldValidator>
    <br/>
    <asp:TextBox ID="TextBox4" runat="server"></asp:TextBox>
    <asp:RequiredFieldValidator ControlToValidate="TextBox4" ID="RequiredFieldValidator4" runat="server" ErrorMessage="RequiredFieldValidator1" ValidationGroup="validationGroupName"></asp:RequiredFieldValidator>
    <br/>
    <asp:Button ID="Button1" runat="server" Text="Button" OnClick="Button1_Click" OnClientClick="RemoveValidationDuplicates('validationGroupName')"/>
</div>

KIRANによってcsharpquery.blogspot.nlに最初に投稿されたソリューション

3月23日更新:javascript関数を変更して再利用可能にし、冗長なコードを削除しました。

于 2013-03-20T18:46:34.013 に答える