JS中的NaN是什么?如何检测?

nan是JS中表示“非数字”的特殊值,类型为number但不等于自身,判断时需注意:1. 使用isnan()可能误判因转换问题;2. 推荐使用es6的number.isnan()精准判断;3. 也可利用nan不等于自身的特性通过value !== value检测。

JS中的NaN是什么?如何检测?

在JS中,NaN表示“Not a Number”,通常出现在数学运算结果无法得到一个有效数字时。比如你用字符串减去数字、除以0、或者做了一些非法的数学操作,都可能得到NaN。

虽然它叫“Not a Number”,但它的类型仍然是number,这是JS设计上的一个历史遗留问题,所以别被名字和类型搞混了。


NaN的特性:不是自己

最让人头疼的一点是,NaN有一个特殊的行为:它不等于自己

NaN === NaN // false

这也是为什么不能直接用===来判断一个值是不是NaN。


常见的检测方法

1. 使用 isNaN()

这是最老的方法:

isNaN(NaN)      // true isNaN('abc')    // true(注意!)

但有个大坑:isNaN()会先尝试把参数转换成数字,如果转换失败才返回true。例如字符串’abc’会被认为是NaN,这可能导致误判。

2. 使用 Number.isNaN()

ES6引入了更准确的判断方式:

Number.isNaN(NaN)     // true Number.isNaN('abc')   // false

这个方法不会对参数做强制转换,只有当值本身就是NaN时才会返回true,推荐优先使用这种方式。

3. 利用 NaN !== NaN

因为NaN是唯一一个不等于自己的值,可以利用这点:

function isNan(value) {   return value !== value; }

虽然看起来有点奇怪,但这招确实好使,而且兼容性很好。


实际应用中的建议

  • 如果你想判断某个变量是否真的是NaN,优先使用 Number.isNaN()
  • 如果你要判断一个表达式的结果是否无效,比如函数返回的是不是非数字,可以用上面几种方法组合使用
  • 注意处理从用户输入或接口获取的数据,避免因类型错误导致误判

基本上就这些。总结来说,NaN是个特殊的值,判断它不能靠常规手段,记住Number.isNaN()和value !== value这两个方法就够了。

© 版权声明
THE END
喜欢就支持一下吧
点赞8 分享