ASP.net MVC 3 Проверка jQuery; Отключить ненавязчивый OnKeyUp? - PullRequest
25 голосов
/ 05 ноября 2011

Есть ли способ отключить валидацию jQuery для определенного валидатора (кредитной карты), чтобы он происходил только onblur, а не onkeyup?

Основываясь на документации jQuery Validator, я подумал, что могу сделать что-то вроде этого:

$(function () {
    $("[data-val-creditcard]").validate({
        onkeyup: false
    })
});

Однако, похоже, это не работает.

Я также попытался сделать следующее на моем валидаторе:

public class CreditCardValidator : DataAnnotationsModelValidator<CreditCardAttribute>
{
    string _message;

    public CreditCardValidator(ModelMetadata metadata, ControllerContext context, CreditCardAttribute attribute)
        : base(metadata, context, attribute)
    {
        _message = attribute.ErrorMessage;
    }

    public override IEnumerable<ModelClientValidationRule> GetClientValidationRules()
    {
        var rule = new ModelClientValidationRule
        {
            ErrorMessage = _message,
            ValidationType = "creditcard"
        };
        rule.ValidationParameters.Add("onkeyup", false);
        return new[] { rule };
    }
}

Это тоже не работает, но я просто попробовал правильное использование ValidationParameters.

Раздражительно вводить номер кредитной карты в форму и случайным образом менять его с недействительного на действительный, а затем обратно на недействительный.

Есть идеи? Спасибо!

Ответы [ 6 ]

20 голосов
/ 18 октября 2012

$.validator.setDefaults не работает для ненавязчивой проверки, так как валидатор инициализируется внутри.

Чтобы изменить настройки в формах, которые используют ненавязчивую проверку, вы можете сделать следующее:

var validator = $("form").data("validator");
if (validator) {
    validator.settings.onkeyup = false; // disable validation on keyup
}
20 голосов
/ 29 декабря 2011

Хорошо, ребята,

Я столкнулся с той же проблемой и обнаружил этот поток: http://old.nabble.com/-validate--onkeyup-for-single-field-td21729097s27240.html

Идея состоит в том, чтобы переписать событие keyup и вернуть false.Таким образом, в вашем конкретном случае вам нужно добавить:

$('#my-form').validate({
   rules: {
     [...]
   }
} 
// Disable keyup validation for credit card field
$("[data-val-creditcard]").keyup(function() { return false } );

И вы увидите, что поле вашей кредитной карты проверяется только на размытие или отправить (но остальное также работает на keyup).

Я искал такое же решение и обнаружил, что ответ здесь можно улучшить, поэтому я подумал, что было бы неплохо поделиться им здесь.

9 голосов
/ 14 января 2013

Я понимаю, что это старый пост, но ни один из ответов не отвечает на этот вопрос,

Как отключить onkeyup и включить onblur?

Я искал это, поэтому думал, что поделюсь ответом.

Как правильно сказал Бен Фостер, onkeyup можно отключить, выполнив следующие действия:

var validator = $("form").data("validator");
if (validator) {
    validator.settings.onkeyup = false;
}

Чтобы включить проверку onblur, мы можем использовать onfocusout

validator.settings.onfocusout = function(element)
{
    $(element).valid();
};

Итак, наш код для отключения onkeyup и включения onblur выглядит следующим образом

var validator = $("form").data("validator");
        if (validator)
        {
            validator.settings.onkeyup = false; 
            validator.settings.onfocusout = function(element)
            {
                $(element).valid();
            };
        }
5 голосов
/ 06 ноября 2011

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

$.validator.setDefaults({
   onkeyup: false
})

См

1 голос
/ 22 апреля 2016

Вы также можете использовать что-то вроде выше,

$("form").validate({
    onfocusout: false,
    onkeyup: false
});

Если у вас есть собственные правила,

$("form").validate({
    onfocusout: false,
    onkeyup: false,
    rules: {
        "name1": {
            required: true,
            email: true,
            maxlength: 100
        },
        "name2": {
            required: true,
            number: true
        }
    }
});

Этот ответ на форуме jQuery мне очень помог.

0 голосов
/ 06 ноября 2011

Вы можете отключить настройки по умолчанию в событии onfocus в поле кредита, а затем включить их в onblur.Кажется, хак, но может работать.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...