View Full Version : drop-down menu dates validation

07-01-2005, 11:08 AM
<script language="javascript">
// Date of Birth Validation //
// Check if Infant < 2 Jahre Alt //
// Check if Child < 12 Jahre Alt //
Date.prototype.getDiff = function(date, interval){
if (typeof date == "string"){
date = new Date(date);
if (isNaN(date) || !(date instanceof Date)){
return NaN;
if (typeof interval == "undefined") interval = "ms";
var diff = this - date;
case "s":
diff = diff/1000; break;
case "n":
diff = diff/(1000*60); break;
case "h":
diff = diff/(1000*60*60); break;
case "d":
diff = diff/(1000*60*60*24); break;
case "m":
diff = diff/(1000*60*60*24*30); break;
case "y":
diff = diff/(1000*60*60*24*365); break;
return Math.floor(diff);

function checkBirthday(obj) {
if( !/^(\d{1,2})\/(\d{1,2})\/(\d{4})$/.test(obj.value) ) {
alert( "Invalid date supplied - must be format DD/MM/YYYY" );

var d = new Date();
var d2 = new Date(RegExp.$3, RegExp.$2, RegExp.$1);

var diff = d.getDiff(d2, "y")
if( isNaN(diff) ) {
alert( "Invalid date supplied" );
else if( diff < 2 ) {
alert( "This IS an INFANT \n they are younger that 2" );
infant = true;
else if( diff > 2 ) {
alert( "This is NOT an INFANT \n they are older that 2" );
infant = false;
document.form.birthday.value = "";




<select name="date<%=k%>"
style="color: black; font: 7pt Verdana, Arial, Helvetica, sans-serif;">
For d = 1 to 31
Response.write "<option value=" & d & ">" & d & "</option>"
<select name="month<%=k%>"
style="color: black; font: 7pt Verdana, Arial, Helvetica, sans-serif;">
For m = 1 to 12
response.Write "<option value=" & m & ">" & MMtoMMM(m) & "</option>"
Dim three_years_ago
three_years_ago = year(date) - 3
<select name="year<%=k%>"
style="color: black; font: 7pt Verdana, Arial, Helvetica, sans-serif;">
For y = three_years_ago to year(date)
Response.Write "<option value=" & y & ">" & y & "</option>"

<input type="text" name="birthday" size="5" style="font:7pt;" value="" maxLength="10">

<img src="images/confirm.gif" alt="Confirm" name="HoldFlights" width="80" height="15" border=0 id=submit1 title="The reservations will be confirmed now" onclick="javascript: checkBirthday(document.form.birthday);return confirmedok();document.body.style.cursor = 'wait';" onMouseOver='style.cursor="hand"' value="Confirm">

I am having a problem with this code. I am looking to have JS validation on the drop-down menus like I said before.
I am trying to put the values of the drop-down menus into a textbox then validate it.
Although, i am experiancing problems. How can i do this? I am trying to check if the date of birth is MORE than two years ago
(i.e. if the infant is older than 2years old). If they are then dont submit the form and show pop-up (ALERT). Else, submit form to next page.

07-06-2005, 01:34 PM
Is there a way to put JavaScript validation onto this top prevent a date being entered that is after TODAYS Date?
The ASP <%=k%> is just a integer value of 1,2,3 etc..

<input type="hidden" name="birthday<%=k%>" size="5" style="font:7pt;" maxLength="10">
Typical Value: 07112005 for 7th November 2005

07-06-2005, 03:16 PM
Hi mate, any chance you could put the credits back in for the getDiff function please. I'm not overly stressed about my own credits in other coder's code, but I didn't write that function and it would be appropriate to include that programmer.



07-06-2005, 03:22 PM
yep, i put them back