在 JavaScript 中,NaN 是一个特殊的值,它表示 Not a Number,但却是一个 Number 类型。因此,在判断一个值是否为 NaN 时,我们不能简单地使用相等运算符 (== 或 ===),而需要使用全局函数 isNaN()。
然而,ES10 引入了一个新的 Array 原型方法 includes(),它可以方便地判断一个数组中是否包含某个值。但是,由于 includes() 方法内部使用的是相等运算符,所以在使用 includes() 方法判断一个数组中是否包含 NaN 时,会出现错误的结果。
下面是一个示例代码:
const arr = [1, 2, NaN]; console.log(arr.includes(NaN)); // false
在上面的代码中,我们使用 includes() 方法判断数组 arr 中是否包含 NaN,但是结果却是 false,这是因为 includes() 方法内部会使用相等运算符来比较两个值是否相等,而 NaN 与任何值都不相等,包括它自己。
为了解决这个问题,我们可以使用 Number.isNaN() 方法来判断一个值是否为 NaN。Number.isNaN() 方法与全局函数 isNaN() 的区别在于,Number.isNaN() 只会返回 true,当传入的值是 NaN 时才会返回 true,而全局函数 isNaN() 会将传入的值转换成数字后再进行判断。
下面是一个使用 Number.isNaN() 方法解决 includes() 方法判断 NaN 的问题的示例代码:
const arr = [1, 2, NaN]; console.log(arr.some(Number.isNaN)); // true
在上面的代码中,我们使用 some() 方法来判断数组 arr 中是否存在一个值是 NaN。some() 方法接受一个回调函数作为参数,当回调函数返回 true 时,some() 方法就会返回 true。由于 Number.isNaN() 方法只会在传入的值是 NaN 时返回 true,因此我们可以使用它来作为 some() 方法的回调函数,从而判断数组中是否存在一个值是 NaN。
总结:
在使用 ES10 的 includes() 方法判断一个数组中是否包含 NaN 时,需要注意 includes() 方法内部使用的是相等运算符,因此不能直接使用 includes() 方法来判断。可以使用 Number.isNaN() 方法来判断一个值是否为 NaN,从而解决 includes() 方法判断 NaN 的问题。
来源:JavaScript中文网 ,转载请注明来源 https://www.javascriptcn.com/post/6587cbfbeb4cecbf2dd077c0