-2

我正在使用 JQuery、KnockOutJs 等创建一个 ASP.NET MVC 应用程序。我有一个用于 SignUp 的模型并且仅使用客户端验证。

public class SignUp
    {
    [Required(ErrorMessageResourceType = typeof(Messages), ErrorMessageResourceName = MessagesConst.UserNameIsRequired, AllowEmptyStrings = false)]
    [StringLength(30, ErrorMessageResourceName = MessagesConst.UserNameLength, ErrorMessageResourceType = typeof(Messages))]
    [RegularExpression(@"^[a-zA-Z ]*$", ErrorMessageResourceType = typeof(Messages), ErrorMessageResourceName = MessagesConst.OnlyAlphabetsAndSpaceAreAllowed)]
    public string UserName { get; set; }

    [RegularExpression(@"^\s*[_A-Za-z0-9-]+(\.[_A-Za-z0-9-]+)*@[A-Za-z0-9-]+(\.[A-Za-z0-9-]+)*(\.[A-Za-z]{2,4})[ ]*$", ErrorMessageResourceType = typeof(Messages), ErrorMessageResourceName = MessagesConst.InvalidEmail)]
    [Required(ErrorMessageResourceType = typeof(Messages), ErrorMessageResourceName = MessagesConst.EmailIsRequired, AllowEmptyStrings = false)]
    [StringLength(256, ErrorMessageResourceName = MessagesConst.EmailLength, ErrorMessageResourceType = typeof(Messages))]
    public string Email { get; set; }

    [DataType(DataType.Password)]
    [StringLength(50, ErrorMessageResourceName = MessagesConst.PasswordRange, ErrorMessageResourceType = typeof(Messages),MinimumLength = 6)]
    [Required(ErrorMessageResourceType = typeof(Messages), ErrorMessageResourceName = MessagesConst.PasswordRequired, AllowEmptyStrings = false)]
    public string Password { get; set; }

    [DataType(DataType.Password)]
    [Compare("Password", ErrorMessageResourceName = MessagesConst.InvalidConfirmPassword, ErrorMessageResourceType = typeof(Messages))]
    public string ConfirmPassword { get; set; }

    public bool IsNewsLetter { get; set; }

    public bool RememberMe { get; set; }
}

我正在查看验证摘要。

 @using (Html.BeginForm("Registration", "Home", FormMethod.Post, new { id = "frmRegistration" }))
    { 
        <div class="msg">
            @Html.ValidationSummary(false)
        </div>
        <h1 class="title">@UserResource.lblSignUp</h1>
        <div class="content_box signup">
            <div class="sign_up">
                <div class="left">
                    <div class="logo">
                        <a href="/" title="Home">
                                                        </a>
                    </div>

                    <div class="feat_text">
                        <h1>@LayoutResources.tglnCF</h1>
                        <p class="subtitle">@LayoutResources.tglnSubTitleCF</p>
                    </div>

                    <div class="bottom_box">
                        <strong>@UserResource.lblAlreadyAccountOnSocialnetwork</strong><br>
                        <span class="sing_in_direct"><a href="/Login">@UserResource.lblSignIn</a> directly from here.</span>
                    </div>
                </div>
                <div class="right">

                    @*Remove Placeholders for validation issue.*@

                    <div class="control-group">
                        <label class="blue">@UserResource.lblUserName</label>
                        <div class="controls">
                            @Html.TextBoxFor(m => m.UserName, new { @data_bind = "value:UserName, valueUpdate:['afterkeydown','propertychange','input']", placeholder = Placeholders.UserName, want_live_validation = true })
                            <span class="help-inline">
                                <span class="sprite"></span>
                            </span>
                            @*@Html.ValidationMessageFor(m => m.UserName)*@
                        </div>
                    </div>
                    <div class="control-group">
                        <label class="blue">@UserResource.lblEmail</label>
                        <div class="controls">
                            @Html.TextBoxFor(m => m.Email, new { @data_bind = "value:Email, valueUpdate:['afterkeydown','propertychange','input']", placeholder = Placeholders.Email, want_live_validation = true })
                            <span class="help-inline">
                                <span class="sprite"></span>
                            </span>
                            @*@Html.ValidationMessageFor(m => m.Email)*@
                        </div>
                    </div>
                    <div class="control-group">
                        <label class="blue">@UserResource.lblPassword</label>
                        <div class="controls">
                            @Html.PasswordFor(x => x.Password, new { @data_bind = "value:Password, valueUpdate:['afterkeydown','propertychange','input']", title = ToolTipResources.ttPassword, placeholder = Placeholders.Password, @class = "tooltip", want_live_validation = true })
                            <span class="help-inline">
                                <span class="sprite"></span>
                            </span>
                            @*@Html.ValidationMessageFor(m => m.Password)*@
                            <div class="m-t5">
                                <div data-bind="css:PasswordStrengthClass()"></div>
                                <span id='result' data-bind="text:PasswordStrengthMessage()"></span>
                            </div>
                        </div>
                    </div>
                    <div class="control-group">
                        <label class="blue">@UserResource.lblConfirmPassword</label>
                        <div class="controls">
                            @Html.PasswordFor(m => m.ConfirmPassword, new { @data_bind = "value:ConfirmPassword, valueUpdate:['afterkeydown','propertychange','input']", placeholder = Placeholders.ConfirmPassword, want_live_validation = true })
                            <span class="help-inline">
                                <span class="sprite"></span>
                            </span>
                            @*@Html.ValidationMessageFor(m => m.ConfirmPassword)*@
                        </div>
                    </div>

                    <label class="checkbox blue" for="checkbox1">
                        @Html.CheckBoxFor(m => m.IsNewsLetter, new { name = "check1", id = "checkTermAndPolicy" })
                        @UserResource.lblDiscoverNewProjectWithWeeklyNewsLetter
                    </label>
                    <p class="terms_text">
                        @UserResource.lblBySignInYouAgreeToOur <a href="/Terms/TermsOfUse.html" target="_blank">@UserResource.lblTermsOfUse</a> @UserResource.lblAnd <a href="/Terms/PrivacyPolicy.html" target="_blank">@UserResource.lblPrivacyPolicy</a>.
                    </p>
                    <div>
                        <p class="errorMassage"></p>
                    </div>
                    <input type="submit" value="SIGN UP">
                </div>
                <div class="clear"></div>
            </div>
        </div>
    }

当前摘要显示为, 在此处输入图像描述 但我想自定义该摘要,例如所有为必填字段触发的验证将显示为(用户名,电子邮件,密码必填。)或为无效字段触发的所有验证将显示为(无效的电子邮件地址用户名,电子邮件。)

4

1 回答 1

1

你可以试试@Html.ValidationSummary().ToString().Replace("\r\n", "").Replace("\n", "").Replace("\r", "")

但是,我不确定validationsummary 是如何吐出它的换行符的,因此您可能会发现并减少它。

于 2013-08-06T14:16:03.633 回答