我对 NaN 的工作方式感到困惑。我已经执行了isNaN(undefined)
它返回true
。但如果我会使用Number.isNaN(undefined)
它会返回false
。那么我应该使用哪一个。还有为什么结果会有如此大的差异。
javascript中isNaN和Number.isNaN之间的混淆
IT技术
javascript
numbers
2021-02-22 08:25:15
5个回答
Number.isNaN 几乎与 ES5 全局 isNaN 方法相同。Number.isNaN 返回提供的值是否等于 NaN。这与“这不是数字吗?”是一个非常不同的问题。
所以isNaN
只需检查传递的值是否不是数字或无法转换为数字。Number.isNaN
另一方面只检查值是否等于NaN
(它使用不同的算法===
)。
'ponyfoo'
例如String不是数字,不能转换为数字,但它不是NaN
。
例子:
Number.isNaN({});
// <- false, {} is not NaN
Number.isNaN('ponyfoo')
// <- false, 'ponyfoo' is not NaN
Number.isNaN(NaN)
// <- true, NaN is NaN
Number.isNaN('pony'/'foo')
// <- true, 'pony'/'foo' is NaN, NaN is NaN
isNaN({});
// <- true, {} is not a number
isNaN('ponyfoo')
// <- true, 'ponyfoo' is not a number
isNaN(NaN)
// <- true, NaN is not a number
isNaN('pony'/'foo')
// <- true, 'pony'/'foo' is NaN, NaN is not a number
isNaN
将参数转换为 aNumber
,如果结果值为 ,则返回 trueNaN
。Number.isNaN
不转换参数;当参数是 aNumber
和 is时,它返回真NaN
。
那么我应该使用哪一个。
我猜您正在尝试检查该值是否看起来像一个数字。在这种情况下,答案都不是。这些函数检查值是否为IEEE-754 Not A Number。时期。例如,这显然是错误的:
var your_age = "";
// user forgot to put in their age
if (isNaN(your_age)) {
alert("Age is invalid. Please enter a valid number.");
} else {
alert("Your age is " + your_age + ".");
}
// alerts "Your age is ."
// same result when you use Number.isNaN above
还有为什么结果会有如此大的差异。
如上所述,Number.isNaN
如果参数不是Number
whileisNaN
首先将值转换为 a ,则将立即返回 false Number
。这会改变结果。一些例子:
| Number.isNaN() | isNaN()
----------------+----------------------------+-----------------------
value | value is a Number | result | Number(value) | result
----------------+-------------------+--------+---------------+-------
undefined | false | false | NaN | true
{} | false | false | NaN | true
"blabla" | false | false | NaN | true
new Date("!") | false | false | NaN | true
new Number(0/0) | false | false | NaN | true
我发现,如果您想检查某些东西是否是数字(或不是),那么结合Number.isNaN()
使用Number.parseInt()
或Number.parseFloat()
(取决于您的期望)可以涵盖大多数用例:
考虑:针对几个数字测试测试一堆不同的输入变量:
r = [NaN, undefined, null, false, true, {}, [], '', ' ', 0, 1, '0', '1']
.map(function(v){return [
v,
isNaN(v),
Number.isNaN(v),
Number.isInteger(v),
Number.parseInt(v, 10),
Number.isNaN( Number.parseInt(v, 10))
];});
console.table(r);
// or if console.table() not available:
r.join('\n', function(v){v.join(',')} );
结果:
NaN , true , true , false, NaN, true
undefined, true , false, false, NaN, true
null , false, false, false, NaN, true
false , false, false, false, NaN, true
true , false, false, false, NaN, true
Object , true , false, false, NaN, true
Array(0) , false, false, false, NaN, true
'' , false, false, false, NaN, true
' ' , false, false, false, NaN, true
0 , false, false, true , 0 , false
1 , false, false, true , 1 , false
'0' , false, false, false, 0 , false
'1' , false, false, false, 1 , false
请注意最后一列,根据我的经验,这通常是我想要的。
不久,
isNaN()
将检查值转换为数字(类型)是否失败
例如'abc'
Number.isNaN()
将检查给定的值类型是否为数字但不是有效数字
例如:'bb'/33
Number.isNaN()
如果值的类型为 Number,则此方法返回 true,并且等于 NaN。否则返回false。例如
Number.isNaN(123) //false
Type of 123 is number but 123 is not equal to NaN, therefore it returns false.
Number.isNaN('123') //false
Type of 123 is string & '123' is not equal to NaN, therefore it returns false.
Number.isNaN(NaN) //true
Type of NaN is number & NaN is equal to NaN, therefore it returns true.
Number.isNaN('NaN') //false
Type of 'NaN' is string & 'NaN' is not equal to NaN, therefore it returns false.
全局isNaN()函数
全局 isNaN() 函数将测试值转换为数字,然后对其进行测试。
isNaN(123) //false
isNaN('123') //false
isNaN(NaN) //true
isNaN('NaN') //true