我尝试了这个没有成功:
window.Parsley.addValidator('date', {
validateString: function(value, format) {
if (! value) {
return true;
}
var date = moment(value, format, true);
return date.isValid();
},
priority: 256,
messages: {
en: 'It must be a valid date with format %s',
it: 'Deve essere una data valida nel formato %s'
}
});
window.Parsley.addValidator('datebeforenow', {
validateString: function(value, format, parsleyField) {
console.log("value", value);
if (! value) {
return true;
}
var $elem = parsleyField.$element;
$elem.attr(parsleyField.options.namespace + 'date', format);
$elem.removeAttr(parsleyField.options.namespace + 'datebeforenow');
$elem.parsley().whenValidate().then(function () {
$elem.attr(parsleyField.options.namespace + 'datebeforenow', format);
$elem.parsley().reset();
var date = moment(value, format, true);
console.log("date", date);
return date.isBefore(moment());
}).always(function () {
$elem.attr(parsleyField.options.namespace + 'datebeforenow', format);
console.log("$elem", $elem)
});
},
priority: 255,
messages: {
en: "Date must be before now",
it: "Inserire una data precedente a quella attuale",
},
});
如果输入无效日期,则会正确显示date
消息,但如果在当前日期之后输入有效日期,则不会显示任何消息。我还试图将较低的优先级设置为date
。
我创建了这个Parsley验证器:
window.Parsley.addValidator('date', {
validateString: function(value, format) {
if (! value) {
return true;
}
var date = moment(value, format, true);
return date.isValid();
},
priority: 256,
});
我有另一个验证器:
window.Parsley.addValidator('datebeforenow', {
validateString: function(value, format) {
if (! value) {
return true;
}
var valid_date = Parsley._validatorRegistry.validators.date.validateString(value, format);
if (! valid_date) {
return true;
}
var date = moment(value, format, true);
return date.isBefore(moment());
},
priority: 256,
});
我希望Parsley._validatorRegistry.validators.date.validateString(value, format);
调用另一个验证器,该字段将显示date
验证器的错误消息,因此我不需要添加两个验证器。但是不会出现错误消息。
在另一个内部调用验证器的正确方法是什么?
Parsley没有机制在验证器之间存在依赖关系。人们一直认为验证者是独立的。
回答原始问题:
由于您需要不同的错误消息,因此使用Parsley处理此情况的唯一正确方法是激活不同的验证(在您的情况下,date
和datebeforenow
)。
一种快速的方法是在生成表单后执行$('[data-parsley-datebeforenow]').attr('data-parsley-date', '')
。