Je saisis les dates de naissance et de décès. Validation requise
Valider ne fonctionne pas comme prévu et ne peut pas résoudre le problème. S'il vous plaît aider.
Bibliothèques JS utilisées
Méthodes supplémentaires pour la bibliothèque de validation
var today = new Date();
var authorValidator = $("#itemAuthorForm").validate({
rules : {
dateOfBirth : {
required : false,
date : true,
dateITA : true,
dateLessThan : '#expiredDate'
},
expiredDate : {
required : false,
date : true,
dateITA : true,
dateGreaterThan : "#dateOfBirth"
}
},
onfocusout : function(element) {
if ($(element).val()) {
$(element).valid();
}
}
});
var dateOptionsDOE = {
maxDate : today,
dateFormat : "dd/mm/yy",
changeMonth : true,
changeYear : true,
onClose : function(selectedDate) {
$("#dateOfBirth").datepicker("option", "maxDate", selectedDate);
}
};
var dateOptionsDOB = {
maxDate : today,
dateFormat : "dd/mm/yy",
changeMonth : true,
changeYear : true,
onClose : function(selectedDate) {
$("#expiredDate").datepicker("option", "minDate", selectedDate);
}
};
jQuery.validator.addMethod("dateGreaterThan",
function(value, element, params) {
if ($(params).val() === "")
return true;
if (!/Invalid|NaN/.test(new Date(value))) {
return new Date(value) > new Date($(params).val());
}
return isNaN(value) && isNaN($(params).val())
|| (Number(value) > Number($(params).val()));
}, 'Must be greater than {0}.');
jQuery.validator.addMethod("dateLessThan",
function(value, element, params) {
if ($(params).val() === "")
return true;
if (!/Invalid|NaN/.test(new Date(value))) {
return new Date(value) < new Date($(params).val());
}
return isNaN(value) && isNaN($(params).val())
|| (Number(value) < Number($(params).val()));
}, 'Must be less than {0}.');
$("#expiredDate").datepicker(
$.extend({}, $.datepicker.regional['en-GB'], dateOptionsDOE));
$("#dateOfBirth").datepicker(
$.extend({}, $.datepicker.regional['en-GB'], dateOptionsDOB));
Vous n'avez pas besoin du validateur date
. Il ne prend pas en charge le format jj/mm/aaaa , et c’est pourquoi vous obtenez le message "Veuillez entrer une date valide", comme le 13/01/2014. Vous avez déjà le validateur dateITA
qui utilise le format jj/mm/aaaa selon vos besoins.
Tout comme le validateur date
, votre code pour dateGreaterThan
et dateLessThan
appelle new Date
pour la chaîne d'entrée et a les mêmes problèmes d'analyse des dates. Vous pouvez utiliser une fonction comme celle-ci pour analyser la date:
function parseDMY(value) {
var date = value.split("/");
var d = parseInt(date[0], 10),
m = parseInt(date[1], 10),
y = parseInt(date[2], 10);
return new Date(y, m - 1, d);
}
Cela permettra également de vérifier l'année bissextile. C'est une regex pure, donc c'est plus rapide que n'importe quelle lib (également plus rapide que moment.js). Mais si vous utilisez beaucoup de dates dans votre code, je vous recommande d'utiliser moment.js
var dateRegex = /^(?=\d)(?:(?:31(?!.(?:0?[2469]|11))|(?:30|29)(?!.0?2)|29(?=.0?2.(?:(?:(?:1[6-9]|[2-9]\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00)))(?:\x20|$))|(?:2[0-8]|1\d|0?[1-9]))([-.\/])(?:1[012]|0?[1-9])\1(?:1[6-9]|[2-9]\d)?\d\d(?:(?=\x20\d)\x20|$))?(((0?[1-9]|1[012])(:[0-5]\d){0,2}(\x20[AP]M))|([01]\d|2[0-3])(:[0-5]\d){1,2})?$/;
console.log(dateRegex.test('21/01/1986'));
Si vous utilisez la bibliothèque moment js, vous pouvez facilement le faire comme ceci -
jQuery.validator.addMethod("validDate", function(value, element) {
return this.optional(element) || moment(value,"DD/MM/YYYY").isValid();
}, "Please enter a valid date in the format DD/MM/YYYY");
J'ai rencontré un problème similaire dans mon projet. Après avoir beaucoup lutté, j'ai trouvé cette solution:
if ($.datepicker.parseDate("dd/mm/yy","17/06/2015") > $.datepicker.parseDate("dd/mm/yy","20/06/2015"))
// do something
Vous n'avez pas besoin de plugins comme jQuery Validate ou Moment.js pour ce problème. J'espère que cette solution aide.
Cela fonctionne bien pour moi.
$(document).ready(function () {
$('#btn_move').click( function(){
var dateformat = /^(0?[1-9]|[12][0-9]|3[01])[\/\-](0?[1-9]|1[012])[\/\-]\d{4}$/;
var Val_date=$('#txt_date').val();
if(Val_date.match(dateformat)){
var seperator1 = Val_date.split('/');
var seperator2 = Val_date.split('-');
if (seperator1.length>1)
{
var splitdate = Val_date.split('/');
}
else if (seperator2.length>1)
{
var splitdate = Val_date.split('-');
}
var dd = parseInt(splitdate[0]);
var mm = parseInt(splitdate[1]);
var yy = parseInt(splitdate[2]);
var ListofDays = [31,28,31,30,31,30,31,31,30,31,30,31];
if (mm==1 || mm>2)
{
if (dd>ListofDays[mm-1])
{
alert('Invalid date format!');
return false;
}
}
if (mm==2)
{
var lyear = false;
if ( (!(yy % 4) && yy % 100) || !(yy % 400))
{
lyear = true;
}
if ((lyear==false) && (dd>=29))
{
alert('Invalid date format!');
return false;
}
if ((lyear==true) && (dd>29))
{
alert('Invalid date format!');
return false;
}
}
}
else
{
alert("Invalid date format!");
return false;
}
});
});
Ceci valide les dates jj/mm/aaaa. Editez votre jquery.validate.js et ajoutez-les.
Référence (Regex): Regex pour valider le format de date jj/mm/aaaa
dateBR: function( value, element ) {
return this.optional(element) || /^(?:(?:31(\/|-|\.)(?:0?[13578]|1[02]))\1|(?:(?:29|30)(\/|-|\.)(?:0?[1,3-9]|1[0-2])\2))(?:(?:1[6-9]|[2-9]\d)?\d{2})$|^(?:29(\/|-|\.)0?2\3(?:(?:(?:1[6-9]|[2-9]\d)?(?:0[48]|[2468][048]|[13579][26])|(?:(?:16|[2468][048]|[3579][26])00))))$|^(?:0?[1-9]|1\d|2[0-8])(\/|-|\.)(?:(?:0?[1-9])|(?:1[0-2]))\4(?:(?:1[6-9]|[2-9]\d)?\d{2})$/.test(value);
}
messages: {
dateBR: "Invalid date."
}
classRuleSettings: {
dateBR: {dateBR: true}
}
Usage:
$( "#myForm" ).validate({
rules: {
field: {
dateBR: true
}
}
});