Como desativar método de validação personalizada, na condição
-
03-07-2019 - |
Pergunta
Eu uso jQuery Validação plug-in para garantir que o usuário entrou positiva cost_of_car no primeiro campo de texto e positivo PAYMENT_AMOUNT no segundo campo de texto como o * cost_of_car * 0,4 <= PAYMENT_AMOUNT <= cost_of_car *:
$.validator.addMethod("testMaxAmount", function()
{
return $("#cost_of_car").val() - 0 >= $("#payment_amount").val() - 0;
}, "Can't be more than cost_of_car");
$.validator.addMethod("testMinAmount", function()
{
return $("#cost_of_car").val() * 0.4 <= $("#payment_amount").val() - 0;
}, "Can't be less than cost_of_car * 0.4");
$("#calc_form").validate(
{
rules:
{
cost_of_car:
{
required: true,
number: true,
min: 1,
max: 10000000
},
payment_amount:
{
required: true,
number: true,
testMaxAmount: true,
testMinAmount: true
}
}
});
Agora eu quero pular verificações testMaxAmount e testMinAmount até cost_of_car é válido. Teste
$("#calc_form").validate().element("#cost_of_car")
ou mesmo
$("#calc_form").validate({ignore: "#payment_amount"}).element("#cost_of_car")
dentro desses métodos leva a navegador da recursão e trava.
Você propor algum outro método para desativar a validação de PAYMENT_AMOUNT até cost_of_car é válido, por favor?
Solução
UPDATE: A mudança tem que estar nas chamadas validator.addMethod()
:
$.validator.addMethod("testMaxAmount", function()
{
if($("#cost_of_car").valid())
return $("#cost_of_car").val() - 0 >= $("#payment_amount").val() - 0;
else
return true;
}, "Can't be more than cost_of_car");
$.validator.addMethod("testMinAmount", function()
{
if($("#cost_of_car").valid())
return $("#cost_of_car").val() * 0.4 <= $("#payment_amount").val() - 0;
else
return true;
}, "Can't be less than cost_of_car * 0.4");
Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow