Number.isNaN和isNaN

NaN(Not-A-Number):

Number类型的特殊非数字值,也就是说NaN是数字类型,但不是个数字。

typeof NaN;//'number'
NaN == NaN || NaN === NaN; //false

NaN为啥不等于NaN?

Number({}); //返回NaN
Number('str'); //返回NaN
Number({}) == Number('str') || Number({}) === Number('str'); //肯定false啊

所以说用{}和'str'强转Number要是相等了,那就不得了了。

isNaN:

只要不是number,返回true;

*在判断前,会先将值强制转换成Number类型

*String,Undefined,Object强制转换Number会返回NaN

*Boolean true为1,false为0

*Null类型为0

isNaN(NaN); //true
isNaN('str'); //true
isNaN(undefined); //true
isNaN({}); // true
isNaN(1); //false
isNaN(true); // false  
isNaN(null); //false

Number.isNaN:

判断是类型是number并且值是NaN,是ES6规范。

Number.isNaN(NaN); //true
Number.isNaN('str'); //false
Number.isNaN(undefined); //false
Number.isNaN({}); // false
Number.isNaN(1); //false
Number.isNaN(true); // false  
Number.isNaN(null); //false

*Number.isNaN会优先判断值类型,不是Number类型,则返回false

*值类型为Number类型,并且值是NaN,才会返回true。也就是说Number.isNaN值判断值是不是NaN,是则为true,不是则为false.

*不能以字面意思理解(字面意思判断条件 '不是个数字',如果返回false,那意思'是个数字'??)

Number.isNaN兼容处理:

Numbar.isNaN = Number.isNaN || function(value){
return typeof value === 'number' && isNaN(value)
}
//利用NaN不等于NaN的特性
Numbar.isNaN = Number.isNaN || function(value){
return value !== value;
}

总结:

如果使用isNaN,那则表示值转换Number类型后是数字还是NaN,是NaN返回true,是数字返回false。

如果使用Number.isNaN,单纯判断值是不是NaN(不转换类型),是NaN为true,不是返回false;

 

你可能感兴趣的:(Number.isNaN和isNaN)