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