Ich habe einen Code geschrieben, der zwei Daten überprüft - sie sind in zwei Tageseingaben aufgeteilt (# enddate-1-dd, # date-1-dd), zwei Monate Eingaben (# enddate-1-mm, #date -1-mm) und 2-Jahres-Eingaben (# enddate-1, # date-1)Kann ich diesen Jquery-Code überhaupt vereinfachen/optimieren?
Ich wollte zuerst einmal überprüfen, dass es sich eigentlich um Nummern handelt, aber dann wollte ich das jeweils überprüfen es ist in einem Datumsformat, im Moment ist es so:
function validate_form() {
retVal = true; // if the statements below fail, return true
if(retVal == true) {
// check whether the available hours they've entered are a valid time!
$(":text").each(function() {
$this = $(this); // cache the object
if (isNaN($this.val())) {
$this.focus();
$.jGrowl('Please enter a valid date!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
if(retVal == true) {
$("#date-1-dd").each(function() {
$this = $(this); // cache the object
if ($this.val() > 31) {
$this.focus();
$.jGrowl('Please enter a valid day, should be no more than 31!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
if(retVal == true) {
$("#enddate-1-dd").each(function() {
$this = $(this); // cache the object
if ($this.val() > 31) {
$this.focus();
$.jGrowl('Please enter a valid day, should be no more than 31!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
if(retVal == true) {
$("#date-1-mm").each(function() {
$this = $(this); // cache the object
if ($this.val() > 12) {
$this.focus();
$.jGrowl('Please enter a valid month, should be no more than 12!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
if(retVal == true) {
$("#enddate-1-mm").each(function() {
$this = $(this); // cache the object
if ($this.val() > 12) {
$this.focus();
$.jGrowl('Please enter a valid month, should be no more than 12!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
if(retVal == true) {
$("#date-1").each(function() {
$this = $(this); // cache the object
if ($this.val() < 1900 || $this.val() > 3000) {
$this.focus();
$.jGrowl('Please enter a valid year!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
if(retVal == true) {
$("#enddate-1").each(function() {
$this = $(this); // cache the object
if ($this.val() < 1900 || $this.val() > 3000) {
$this.focus();
$.jGrowl('Please enter a valid year!', { theme: 'smoke' });
retVal = false; return false;
}
});
}
return retVal; // return either true or false, depending on what happened up there!^
}
Sorry, wenn es scheint, als ob ich eine dumme Frage bin gefragt, wie mein Code in Ordnung arbeitet, ich denke nur, es ist Müllweg von es zu tun, mit vielen Wiederholungen, aber ich kann mir wirklich keinen Weg vorstellen, es effizienter zu machen?
Dank
Das ist fantastisch, danke !! – Nick