ASP.NET MVC2 Пользовательская проверка jQuery: на стороне клиента - PullRequest
1 голос
/ 20 мая 2010

Я хочу создать правило проверки для 2 сборщиков дат (startDate меньше, чем endDate).

Я создаю атрибут проверки:

[AttributeUsage(AttributeTargets.Class, AllowMultiple = true, Inherited = true)]
public sealed class DateCompareAttribute : ValidationAttribute
{
    private const string _defaultErrorMessage = "'{0}' is less then '{1}'.";

    public DateCompareAttribute(string startDateProperty, string endDateProperty)
        : base(_defaultErrorMessage)
    {
        StartDateProperty = startDateProperty;
        EndDateProperty = endDateProperty;
    }

    public string StartDateProperty { get; private set; }
    public string EndDateProperty { get; private set; }


    public override string FormatErrorMessage(string name)
    {
        return String.Format(CultureInfo.CurrentUICulture, ErrorMessageString, StartDateProperty, EndDateProperty);
    }

    public override bool IsValid(object value)
    {
        PropertyDescriptorCollection properties = TypeDescriptor.GetProperties(value);
        object startValue = properties.Find(StartDateProperty, true).GetValue(value);
        object endValue = properties.Find(EndDateProperty, true).GetValue(value);
        if (startValue.GetType() == typeof(DateTime?) && endValue.GetType() == typeof(DateTime?))
        {
            var start = ((DateTime?)startValue);
            var end = ((DateTime?)endValue);
            return (start.Value < end.Value);
        }
        return false;
    }
}

и добавил к моему Dto:

[DateCompare("StartDate", "EndDate")]
public class QualificationInput{...}

Я создал валидатор:

public class DateCompareValidator : DataAnnotationsModelValidator<DateCompareAttribute>
{
    string startField;
    private string endField;
    string _message;

    public DateCompareValidator(ModelMetadata metadata, ControllerContext context, DateCompareAttribute attribute)
        : base(metadata, context, attribute)
    {
        startField = attribute.StartDateProperty;
        endField = attribute.EndDateProperty;
        _message = attribute.ErrorMessage;
    }

    public override IEnumerable<ModelClientValidationRule> GetClientValidationRules()
    {
        var rule = new ModelClientValidationRule
        {
            ErrorMessage = _message,
            ValidationType = "dateCompare"
        };
        rule.ValidationParameters.Add("startField", startField);
        rule.ValidationParameters.Add("endField", endField);

        return new[] { rule };
    }
}

И зарегистрировал его в Global.asax.cs в Application_Start ():

DataAnnotationsModelValidatorProvider.RegisterAdapter(typeof(DateCompareAttribute), typeof(DateCompareValidator));

В MicrosoftMvcJQueryValidation.js я внес следующие изменения:

switch (thisRule.ValidationType)
{
.....
   case "dateCompare":
      __MVC_ApplyValidator_DateCompare(rulesObj,
      thisRule.ValidationParameters["startField"], thisRule.ValidationParameters["endField"]);
      break;
.....
}

function __MVC_ApplyValidator_DateCompare(object, startField, endField) {
    object["startField"] = startField;
    object["endField"] = endField;
}

jQuery.validator.addMethod("dateCompare", function(value, element, params) {
    if ($('#' + params["startField"]).val() < $('#' + params["endField"]).val())
    { return true; }
    return false;
}, jQuery.format("Error"));

Но это не работает :( нет проверки на стороне клиента для этого типа правил (другие типы, как требуется, работают нормально)

Что я делаю не так?

Ответы [ 3 ]

2 голосов
/ 27 августа 2010

Вам не нужно изменять MicrosoftMvcJQueryValidation.js.Недавно мне пришлось самому заняться этой проблемой, и может помочь следующее:

http://www.deepcode.co.uk/2010/08/custom-mvc-2-validation-using-jquery.html

1 голос
/ 05 ноября 2010

Похоже, что вы применяете атрибут DateCompare к классу ViewModel (а не к свойствам). Это действительно для проверки сервера, но означает, что у нее нет шанса включить проверку клиента. Смотри http://blogs.msdn.com/b/stuartleeks/archive/2010/08/06/asp-net-mvc-adding-client-side-validation-to-propertiesmustmatchattribute.aspx.

1 голос
/ 20 мая 2010

Я бы скопировал и вставил все это, но я думаю, что лучше всего прочитать руководство Фила Хаака по пользовательской проверке в MVC

Во-первых, нам нужен модельный класс. Давайте сделаем что-то простое, как Клиент:

public partial class Customer
{
    public string Name { get; set; }
    public int Age { get; set; }
}

тогда ваша логика проверки

[MetadataType(typeof(CustomerMetaData))]
public partial class Customer
{
    class CustomerMetaData
    {
        [Required(ErrorMessage="You must supply a name for a customer.")]
        [StringLength(50, ErrorMessage = "A customer name cannot exceed 50 characters.")]
        public string Name { get; set; }
    }
}

затем подключите свои скрипты

<script type="text/javascript" src="../../Scripts/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="../../Scripts/jquery.validate.min.js"></script>
<script type="text/javascript" src="../../Scripts/MicrosoftMvcJQueryValidation.js"></script>

Наконец, где-то перед началом вашего тега формы, добавьте следующую разметку в код представления:

<% Html.EnableClientValidation(); %>
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...