Number.isNaN() method determines whether the passed value is NaN and its type is Number . It is a more robust version of the original, global isNaN() .

The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.

句法

Number.isNaN(value)
					

参数

value
The value to be tested for NaN .

返回值

true if the given value is NaN and its type is Number ; otherwise, false .

描述

Due to both equality operators, == and === , evaluating to false when checking if NaN is NaN , the function Number.isNaN() has become necessary. This situation is unlike all other possible value comparisons in JavaScript.

In comparison to the global isNaN() function, Number.isNaN() doesn't suffer the problem of forcefully converting the parameter to a number. This means it is now safe to pass values that would normally convert to NaN , but aren't actually the same value as NaN . This also means that only values of the type number, that are also NaN , return true .

Polyfill

The following works because NaN is the only value in javascript which is not equal to itself.

Number.isNaN = Number.isNaN || function isNaN(input) {
    return typeof input === 'number' && input !== input;
}
					

范例

Using isNaN

Number.isNaN(NaN);        // true
Number.isNaN(Number.NaN); // true
Number.isNaN(0 / 0);      // true
// e.g. these would have been true with global isNaN()
Number.isNaN('NaN');      // false
Number.isNaN(undefined);  // false
Number.isNaN({});         // false
Number.isNaN('blabla');   // false
// These all return false
Number.isNaN(true);
Number.isNaN(null);
Number.isNaN(37);
Number.isNaN('37');
Number.isNaN('37.37');
Number.isNaN('');
Number.isNaN(' ');
					

规范

规范
ECMAScript (ECMA-262)
The definition of 'Number.isnan' in that specification.

浏览器兼容性

The compatibility table in this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request. 更新 GitHub 上的兼容性数据
Desktop Mobile Server
Chrome Edge Firefox Internet Explorer Opera Safari Android webview Chrome for Android Firefox for Android Opera for Android Safari on iOS Samsung Internet Node.js
isNaN Chrome 25 Edge 12 Firefox 15 IE No Opera 15 Safari 9 WebView Android ≤37 Chrome Android 25 Firefox Android 15 Opera Android 14 Safari iOS 9 Samsung Internet Android 1.5 nodejs 0.10

图例

完整支持

完整支持

不支持

不支持

另请参阅

元数据

  • 最后修改: