1

我正在使用 MVC3 和 razaor 视图引擎

我正在尝试确保密码和确认密码应该匹配,但这对我不起作用。它只是不断告诉我“密码”和“确认密码”不匹配。

我使用了“compare”和“equalto”,两者都导致相同的错误。

商业实体:

namespace Project.BusinessEntities
{
    public partial class RegisterPasswordUpdate
    {
        public string Password { get; set; }
        public string ConfirmPassword { get; set; }
        public string UserId { get; set; }
    }
}

验证:

using System.ComponentModel.DataAnnotations;
using DataAnnotationsExtensions;
using System.Web.Mvc;
using Project.Resources;


namespace Project.BusinessEntities
{
    [MetadataType(typeof(RegisterPasswordUpdate.RegisterPasswordUpdateMetaData))]
    public partial class RegisterPasswordUpdate
    {
        public class RegisterPasswordUpdateMetaData
        {
            [Required(ErrorMessage = ValidationMessageConstants.ResponseRequired)]
            [StringLength(16, MinimumLength = 8)]
            [RegularExpression(@"[A-Za-z0-9]*", ErrorMessage = ValidationMessageConstants.AlphaNumericOnly)]
            public string Password { get; set; }

            [Required(ErrorMessage = ValidationMessageConstants.ResponseRequired)]
            [StringLength(16, MinimumLength = 8, ErrorMessage = ValidationMessageConstants.MinimumLength)]
            [RegularExpression(@"[A-Za-z0-9]*", ErrorMessage = ValidationMessageConstants.AlphaNumericOnly)]
            [EqualTo("Password", ErrorMessage = ValidationMessageConstants.ConfirmPassword)]
            public string ConfirmPassword { get; set; }


        }
    }
}

利用:

@Html.TextBoxFor(x => x.PasswordUpdate.Password, new { maxlength = "16", size = "16" })
@Html.ValidationMessageFor(x => x.PasswordUpdate.Password)

@Html.TextBoxFor(x => x.PasswordUpdate.ConfirmPassword, new { maxlength = "16", size = "16" })
@Html.ValidationMessageFor(x => x.PasswordUpdate.ConfirmPassword)

html:

<input data-val="true" data-val-length="The field Password must be a string with a minimum length of 8 and a maximum length of 16." data-val-length-max="16" data-val-length-min="8" data-val-regex="Only alphanumeric (A-Z a-z 0-9) values are allowed" data-val-regex-pattern="[A-Za-z0-9]*" data-val-required="Response required!" id="PasswordUpdate_Password" maxlength="16" name="PasswordUpdate.Password" size="16" type="text" value="" />

<span class="field-validation-valid" data-valmsg-for="PasswordUpdate.Password" data-valmsg-replace="true"></span>

<input data-val="true" data-val-equalto="Password and confirm password do not match" data-val-equalto-other="*.Password" data-val-length="Minimum length not met" data-val-length-max="16" data-val-length-min="8" data-val-regex="Only alphanumeric (A-Z a-z 0-9) values are allowed" data-val-regex-pattern="[A-Za-z0-9]*" data-val-required="Response required!" id="PasswordUpdate_ConfirmPassword" maxlength="16" name="PasswordUpdate.ConfirmPassword" size="16" type="text" value="" />

<span class="field-validation-valid" data-valmsg-for="PasswordUpdate.ConfirmPassword" data-valmsg-replace="true"></span>

页面上的html id:

PasswordUpdate_Password PasswordUpdate_ConfirmPassword

页面上的html名称:

PasswordUpdate.Password PasswordUpdate.ConfirmPassword

这里缺少什么?

4

1 回答 1

1

It is a bug and the following post helped fix it: http://forums.asp.net/t/1716181.aspx/1

The problem lies in missing single quotes in theunobtrusive validation code. This line is incorrect:

 element = $(options.form).find(":input[name=" + fullOtherName + "]")[0];

and should be replace by

element = $(options.form).find(":input[name='" + fullOtherName + "']")[0];
于 2013-05-20T22:52:30.630 回答