"RobG" <rg***@iinet.net.auwrote in message
news:11*********************@57g2000hsv.googlegrou ps.com...
On Sep 29, 6:23 am, "Paul E. Schoen" <pst...@smart.netwrote:
>"Randy Webb" <HikksNotAtH...@aol.comwrote in message
news:eb*********************@giganews.com...
Paul E. Schoen said the following on 9/28/2007 4:24 AM:
I just noticed that my javascript app gives the wrong year in IE, but
correct in Firefox, when I use:
>Form1.ApplicationDate.value = (now.getMonth()+1) + "/" +
now.getDate() +
"/" + (now.getYear()+1900);
>In IE, I get 9/28/3907.
>I could not find specific reference to this in the FAQs and
>>http://www.merlyn.demon.co.uk/js-dates.htm
>Do I need to detect the browser and compensate accordingly?
No, don't detect a browser. Use getFullYear instead and forget about
having to add 1900 at all.
Thanks. That worked well. My old Javascript reference book does not have
that function listed, but it specifies the getYear() function as years
since 1900. Why is it wrong in IE? Or is that a silly question?
Because MS decided that IE would implement a non-standard version of
getYear:
<URL: http://msdn2.microsoft.com/en-us/library/x0a9sc10.aspx >
Don't bother with books when better resources are available online,
the MS JScript reference is here:
<URL: http://msdn2.microsoft.com/en-us/library/hbxc2t98.aspx >
And their DOM (DHTML) reference is here:
<URL: http://msdn2.microsoft.com/en-us/library/ms533050.aspx >
I'll presume you know where to find the W3C and other references.
It is even more frustrating that the original version 1.0 worked
"properly", and then for some reason they broke it, and made it obsolete:
"For JScript version 1.0, getYear returns a value that is the result of the
subtraction of 1900 from the year value in the provided Date object,
regardless of the value of the year. For example, the year 1899 is returned
as -1 and the year 2000 is returned as 100."
My book "Using JScript" by Mark Reynolds was Copyright 1997 (and the CD was
1996), so that was just before the Y2K craziness. But it seems that they
broke the getYear() function in the worst possible way:
"For the years 1900 though 1999, the year is a 2-digit integer value
returned as the difference between the stored year and 1900. For dates
outside that period, the 4-digit year is returned. For example, 1996 is
returned as 96, but 1825 and 2025 are returned as-is."
It was supposed to return a 2-digit integer, but it became 3-digit in 2000.
If it were truly modulus 100, it would have been OK for the popular
two-digit year, but would give wrong results if the +1900 were used. But
the way it was worked fine in most cases. Making a special case of years
from 1900-1999 rendered the function useless, as there was no simple way to
determine if the date were within that range, and adjust accordingly. It
seems like a lesson in "if it ain't broke, don't fix it", and they broke it
by attempting a clumsy fix. Then they had to declare a new function and
make the original obsolete.
I hope there aren't too many stupid differences among the various popular
browsers. It appears that the FAQ and the merlyn pages cover these pretty
well, so I guess I'll just have to read up on other functions I might use.
Thanks for all the helpful discussion.
Paul