JavaScript中Date对象的getYear()和getFullYear()区别

 今天第一次用Date中得getYear时,2013年变成了113年,2007年变成了107年。

上网求解得:


getYear():

使用getYear()函数,是为了获取年份。以2013为例的话

在IE、遨游浏览器中是正确的,显示为:2013;

而在chrome、火狐、Safari、Opera,360浏览器都是显示的:113;

原因则是 在 chrome等浏览器内 getYear 返回的是 "当前年份-1900" 的值(即年份基数是1900)

而IE则是 当today的年份大于等于2000的时,直接将1900加上了,返回的 2010。不过在1900~1999之间只显示后两位。





getFullYear():

用getFullYear()函数就可以避免这个问题,在各种浏览器中都显示的是正确的时间:2013;

所以使用js来获取年份一般都使用: getFullYear():



转:

下面总结下getYear、getFullYear和getUTCFullYear的不同点:


    getYear、getFullYear、getUTCFullYear都是Javascript的Date对象的方法函数。其中getYear()方法出生较早,在早期也一直使用OK,可是在2000年后这个方法问题多多,因为在Firefox和Safari等浏览器上,getYear始终返回年份与1900 年之间的差,比如1998年返回98,而2009年则会显示109,如果大家都这么处理也好,要加一起加,微软自己在IE浏览器中把getYear给修正了,可Firefox(最新版本也没修正这个问题)还蒙在鼓里,仍老老实实的按照原有规则解析getYear,本来都可以指望用户自行修正,这样一来都没得用,于是getFullYear、getUTCFullYear就出生了。

      1、getYear()函数

       使用getYear()方法可返回两位或四位数的年份,用getYear()返回的数并不一定是4位的!处于1900年和1999年间的getYear()方法返回的只有两位数。在此之前的或是在此之后的年份返回的都是四位数的,比如2009年,Javascript解析器应该是返回2009的,而浏览器则计算返回109。这应该是早期的约定,而IE埋头改掉了。该函数已经被逐渐废弃并不推荐使用。

       <script type="text/javascript">

              var d = new Date();

              document.write(d.getYear());//IE输出2009,FIREFOX输出109

       </script>


      2、getFullYea()函数

       getFullYear函数则不存在此问题。getFullYear()方法可返回一个四位数年份,这样大家(IE和FIREFOX等)都不需要运算,直接把解析值输出来即可。

       <script type="text/javascript">

              var d = new Date();

              document.write(d.getFullYear());//IE输出2009,FIREFOX输出2009

       </script>


      3、getUTCFullYear()函数

       getUTCFullYear()函数则是根据UTC时间返回了四位数来代表年份。与getFullYear()方法理论角度是完全不同,虽然在大部分的时间里输出是相同的,但是假如当天日期是12月31日或1月1日,则getUTCFullYear() 返回值与getFullYear()返回值就有可能不同,具体取决于当地时区和UTC通用时间之间的关系,也就是差值。

       <script type="text/javascript">

              var d = new Date();

              document.write(d.getUTCFullYear());//IE输出2009,FIREFOX输出2009

       </script>

       比如在中国大陆、、香港、澳门、蒙古国、台湾、新加坡、马来西亚、菲律宾等地区的本地时间比UTC快8小时,记作UTC+8,意思就是比UTC时间快8小时。减的类似理解,比如UTC-10等。



  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值