手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >关于js new Date() 出现NaN 的分析
关于js new Date() 出现NaN 的分析
摘要:此NaN不为NaN:程序代码如下:复制代码代码如下:vardate=newDate(d);if(!date||!date.getFullYe...

此NaN不为NaN:

程序代码如下:

复制代码 代码如下:

var date =new Date(d);

if(!date || !date.getFullYear) {

return;

}

return S.Date.format(d,'yyyy-mm-dd');//格式化函数,跟此文无关

在其他浏览器下正常,但是在ie下,程序报错

在ie调试器下,发现date 为NaN,如图:

关于js new Date() 出现NaN 的分析1

关于js new Date() 出现NaN 的分析2

如果是NaN,那么if判断会返回true,会 return "",但是诡异的一幕发生了,

关于js new Date() 出现NaN 的分析3

代码说明if判断返回了false,控制台的结果也说明了这一点:

关于js new Date() 出现NaN 的分析4

可以看出date = NaN,但是 !date 为false,!NaN 为 true,我的第一反应,ie下JS的Bug?

然后又做了一些测试

复制代码 代码如下:

var date = NaN;

alert(!date) //返回true

var date = new Date('2011-1-1');

alert(!date) //返回false

但是我想了一下还是不太对,又在控制台做了下面的测试:

关于js new Date() 出现NaN 的分析5

这个说明date的getFullYear是存在的,那么date是个对象

关于js new Date() 出现NaN 的分析6

这个也说明了,date是个object 而不是 NaN,仅仅是ie调试器的一个问题

date.getFullYear() =》NaN

date.getDate() =》NaN

这些NaN则为真正的NaN

总结 :

在ie下 new Date('date text') 时返回的结果是一个特殊的日期对象,只是ie调试器将之显示成了NaN, 对其调用返回number的方法将都会返回NaN.

【关于js new Date() 出现NaN 的分析】相关文章:

匹配html标记的正则

JavaScript基于setTimeout实现计数的方法

Javascript实现div的toggle效果实例分析

基于javascript简单实现对身份证校验

jQuery实现的多屏图像图层切换效果实例

js+html5实现canvas绘制镂空字体文本的方法

Webpack 实现 AngularJS 的延迟加载

JS+CSS实现的拖动分页效果实例

原生js实现的贪吃蛇网页版游戏完整实例

基于jQuery实现的无刷新表格分页实例

精品推荐
分类导航