jQuery.validator.unobtrusive.adapters.addMinMax циклы, не работает в MVC3 - PullRequest
7 голосов
/ 02 июня 2011

Я создаю валидатор дневного диапазона, используя DataAnnotations, jQuery.validate и jquery.validate.unobtrusive. Я уже прочитал следующее: http://bradwilson.typepad.com/blog/2010/10/mvc3-unobtrusive-validation.html

http://weblogs.asp.net/mikaelsoderstrom/archive/2010/10/06/unobtrusive-validation-in-asp-net-mvc-3.aspx

и другие, но не могу их опубликовать (noob)

Как и большинство постов на SO. Я забив головой об стену, любая помощь может быть вознаграждена пивом / едой / кодом / и т. Д .; в любом случае вот код:

У меня есть объект модели со следующим параметром:

[Display(Name = "Start date"), 
 DayRange(0, 5, ErrorMessage = "The Start Date must be between today and 5 days time.")]
public DateTime StartDate { get; set; }

DayRange - это класс пользовательских атрибутов:

[AttributeUsage(AttributeTargets.Field | AttributeTargets.Property, AllowMultiple = false, Inherited = true)]
public class DayRangeAttribute : RangeAttribute, IClientValidatable
{
    private int _minimumDays;
    private int _maximumDays;

    public DayRangeAttribute(int minimumDays, int maximumDays) : base(minimumDays, maximumDays) 
    {
        _minimumDays = minimumDays;
        _maximumDays = maximumDays;
    }

    public override bool IsValid(object value)
    {
        var dateToBeTested = value as DateTime?;
        return dateToBeTested.HasValue && dateToBeTested.Value >= DateTime.Today.AddDays(_minimumDays) && dateToBeTested.Value <= DateTime.Today.AddDays(_maximumDays);
    }

    public IEnumerable<ModelClientValidationRule> GetClientValidationRules(ModelMetadata metadata, ControllerContext context)
    {
        var rule = new ModelClientValidationRule
                         {
                             ErrorMessage = this.ErrorMessage,
                             ValidationType = "dayrange"
                         };
        rule.ValidationParameters.Add("min", _minimumDays);
        rule.ValidationParameters.Add("max", _maximumDays);
        yield return rule;
    }
}

В моем web.config есть следующее:

<appSettings>
    <add key="ClientValidationEnabled" value="true"/>
    <add key="UnobtrusiveJavaScriptEnabled" value="true"/>
</appSettings>

У меня есть следующий JS триггер до того, как документ будет готов (пробовал запускать его, когда документ тоже готов):

jQuery.validator.addMethod('dayrange', function (value, element, param) {
    if (!value) return false;
    var now = Date();
    var dateValue = Date.parse(value);
    var minDate = now.setDate(now.getDate() - param.min);
    var maxDate = now.setDate(now.getDate() + param.max);

    return this.optional(element) && dateValue >= minDate && dateValue <= maxDate;
}, 'Must fall in range');

jQuery.validator.unobtrusive.adapters.addMinMax('dayrange', 'minlength', 'maxlength', 'dayrange');

Что я делаю не так? Заранее спасибо, Jol

Ответы [ 2 ]

19 голосов
/ 03 июня 2011

Решено!Я забыл / не понял, что вы должны передать сам jQuery в функцию закрытия.Поэтому пользовательский валидатор на стороне клиента должен выглядеть следующим образом:

$(function () {
    jQuery.validator.addMethod('dayRange', function (value, element, param) {
        if (!value) return false;
        var valueDateParts = value.split(param.seperator);
        var minDate = new Date();
        var maxDate = new Date();
        var now = new Date();
        var dateValue = new Date(valueDateParts[2],
                            (valueDateParts[1] - 1),
                             valueDateParts[0],
                             now.getHours(),
                             now.getMinutes(),
                             (now.getSeconds()+5));

        minDate.setDate(minDate.getDate() - parseInt(param.min));
        maxDate.setDate(maxDate.getDate() + parseInt(param.max));

    return dateValue >= minDate && dateValue <= maxDate;
});

    jQuery.validator.unobtrusive.adapters.add('dayrange', ['min', 'max', 'dateseperator'], function (options) {
        var params = {
            min: options.params.min,
            max: options.params.max,
            seperator: options.params.dateseperator
        };

        options.rules['dayRange'] = params;
        if (options.message) {
            options.messages['dayRange'] = options.message;
        }
    });
}(jQuery));

Я также изменяю способ добавления адаптера к ненавязчивому, чтобы добавить дополнительные свойства.Никогда не отправляйте на серверную разработку, чтобы выполнить работу переднего инженера;) Надеюсь, это кому-нибудь поможет.

2 голосов
/ 21 октября 2011

Ссылка: http://bradwilson.typepad.com/blog/2010/10/mvc3-unobtrusive-validation.html

Параметр

adapters.addMinMax() имеет следующий вид:

adapterName, minRuleName, maxRuleName, minMaxRuleName, minAttribute, maxAttribute

так что вам нужно это:

jQuery.validator.unobtrusive.adapters.addMinMax('dayrange', '', '', 'dayrange','minlength', 'maxlength');

AND,,,

param.min, param.max be sure to undefine. param is an purely array as: ['111','000'].

так что вам нужно:

var minDate = now.setDate(now.getDate() - param[0]);
var maxDate = now.setDate(now.getDate() + param[1]);
...