JavaScript 中的 NaN
- 什么是
NaN
- 什么时候会返回 NaN
- 判断 NaN
- 参考
什么是 NaN
在 MDN 的 NaN 文章中有描述:
- 全局属性 NaN 表示 Not-A-Number 的值。
- NaN 是一个全局对象的属性。
- NaN 属性的初始值就是 NaN,和 Number.NaN 的值一样。
- 在 ES5 中, NaN 属性是一个不可配置(non-configurable),不可写(non-writable)的属性。但在 ES3 中,这个属性的值是可以被更改的,但是也应该避免覆盖。
- 通常都是在计算失败时,作为 Math 的某个方法的返回值出现的(例如:
Math.sqrt(-1)
)或者尝试将一个字符串解析成数字但失败了的时候(例如:parseInt("blabla")
)。
NaN 的类型
typeof NaN // "number"
也就是说 NaN
是一种特殊的 Number
类型值。
什么时候会返回 NaN
JavaScript 权威指南 中『3.1.3 JavaScript 中的算数运算』章节里有描述:
无穷大除以无穷大、给任意负数做开方运算 或者 算数运算符与不是数字或无法转换为数字的操作数一起使用时都将返回
NaN
。
可分开解释为以下等情况:
- 无穷大除以无穷大
- 给任意负数做开方运算
- 算数运算符与不是数字或无法转换为数字的操作数一起使用
- 字符串解析成数字
以下结果都是 NaN
:
Infinity / Infinity; // 无穷大除以无穷大 Math.sqrt(-1); // 给任意负数做开方运算 'a' - 1; // 算数运算符与不是数字或无法转换为数字的操作数一起使用 'a' * 1; 'a' / 1; parseInt('a'); // 字符串解析成数字 parseFloat('a');
这里的『无法转换为数字的操作』又是什么鬼?
先看下面可以转换为数字的操作例子:
Math.sqrt('4'); // 2 2 * '2'; // 4 '4' / 2; // 2
无法转换为数字的操作
这里涉及到 JavaScript 的 类型转换 的概念。
JavaScript 权威指南 『3.8 类型转换』章节有描述:
如果 JavaScript 期望使用一个数字,它把给定的值将转换为数字(如果转换结果无意义的话将返回 NaN)。
可以使用 Number()
方法做显式类型转换,举例:
Number('1'); // 1 Number(null); // 0 Number('a'); // NaN
也可以使用一元运算符 +
做隐式转换,举例:
+'1'; // 1 +null; // 0 +'a'; // NaN
也可以使用全局函数 parseInt()
和 parseFloat()
解析整数和浮点数,举例:
parseInt('12'); // 12 parseInt('12a'); // 12 parseInt('a12'); // NaN parseInt(null); // NaN
parseInt()
和 parseFloat()
可以简单理解为:
尽可能解析更多数值字符,并且忽略后面的内容;如果第一个非空格字符是非数字,则会返回
NaN
需要注意的是 Number()
和 parseInt()``parseFloat()
,对某些输入值的处理不同,如 null
。
非数字类型转换 为 数字类型,如下表汇总:
值 | 数字 |
---|---|
undefined | NaN |
null | 0 |
true | 1 |
false | 0 |
"" (空字符串) | 0 |
"1.2" (非空,数字) | 1.2 |
"one" (非空,非数字) | NaN |
[] (任意对象) | 0 |
[9] (一个数字元素) | 9 |
['a'] (其他数组) | NaN |
function(){} (任意函数) | NaN |
如何判断 NaN
首先全局的 isNaN()
函数不能严格判断输入值是否为 NaN
。
isNaN()
的怪异行为
在 MDN 的 isNaN() 文章中对 非数值参数 所表现的『怪异行为』有解释:
它会先尝试将这个参数转换为数值,然后才会对转换后的结果是否是
NaN
进行判断。
因此,对于能被强制转换为有效的非
NaN
数值来说,返回false
值也许会让人感觉莫名其妙。
如下例子:
isNaN('37'); // false: 可以被转换成数值 37 isNaN(''); // false: 空字符串被转换成 0
严格判断 NaN
参考 MDN 中 Number.isNaN()
的 Polyfill 代码:
typeof value === 'number' && isNaN(value)
推荐教程:《JS教程》
Atas ialah kandungan terperinci JavaScript 中的 NaN. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Cara menggunakan WebSocket dan JavaScript untuk melaksanakan sistem pengecaman pertuturan dalam talian Pengenalan: Dengan perkembangan teknologi yang berterusan, teknologi pengecaman pertuturan telah menjadi bahagian penting dalam bidang kecerdasan buatan. Sistem pengecaman pertuturan dalam talian berdasarkan WebSocket dan JavaScript mempunyai ciri kependaman rendah, masa nyata dan platform merentas, dan telah menjadi penyelesaian yang digunakan secara meluas. Artikel ini akan memperkenalkan cara menggunakan WebSocket dan JavaScript untuk melaksanakan sistem pengecaman pertuturan dalam talian.

WebSocket dan JavaScript: Teknologi utama untuk merealisasikan sistem pemantauan masa nyata Pengenalan: Dengan perkembangan pesat teknologi Internet, sistem pemantauan masa nyata telah digunakan secara meluas dalam pelbagai bidang. Salah satu teknologi utama untuk mencapai pemantauan masa nyata ialah gabungan WebSocket dan JavaScript. Artikel ini akan memperkenalkan aplikasi WebSocket dan JavaScript dalam sistem pemantauan masa nyata, memberikan contoh kod dan menerangkan prinsip pelaksanaannya secara terperinci. 1. Teknologi WebSocket

Pengenalan kepada cara menggunakan JavaScript dan WebSocket untuk melaksanakan sistem pesanan dalam talian masa nyata: Dengan populariti Internet dan kemajuan teknologi, semakin banyak restoran telah mula menyediakan perkhidmatan pesanan dalam talian. Untuk melaksanakan sistem pesanan dalam talian masa nyata, kami boleh menggunakan teknologi JavaScript dan WebSocket. WebSocket ialah protokol komunikasi dupleks penuh berdasarkan protokol TCP, yang boleh merealisasikan komunikasi dua hala masa nyata antara pelanggan dan pelayan. Dalam sistem pesanan dalam talian masa nyata, apabila pengguna memilih hidangan dan membuat pesanan

Cara menggunakan WebSocket dan JavaScript untuk melaksanakan sistem tempahan dalam talian Dalam era digital hari ini, semakin banyak perniagaan dan perkhidmatan perlu menyediakan fungsi tempahan dalam talian. Adalah penting untuk melaksanakan sistem tempahan dalam talian yang cekap dan masa nyata. Artikel ini akan memperkenalkan cara menggunakan WebSocket dan JavaScript untuk melaksanakan sistem tempahan dalam talian dan memberikan contoh kod khusus. 1. Apakah itu WebSocket? WebSocket ialah kaedah dupleks penuh pada sambungan TCP tunggal.

JavaScript dan WebSocket: Membina sistem ramalan cuaca masa nyata yang cekap Pengenalan: Hari ini, ketepatan ramalan cuaca sangat penting kepada kehidupan harian dan membuat keputusan. Apabila teknologi berkembang, kami boleh menyediakan ramalan cuaca yang lebih tepat dan boleh dipercayai dengan mendapatkan data cuaca dalam masa nyata. Dalam artikel ini, kita akan mempelajari cara menggunakan teknologi JavaScript dan WebSocket untuk membina sistem ramalan cuaca masa nyata yang cekap. Artikel ini akan menunjukkan proses pelaksanaan melalui contoh kod tertentu. Kami

Penggunaan: Dalam JavaScript, kaedah insertBefore() digunakan untuk memasukkan nod baharu dalam pepohon DOM. Kaedah ini memerlukan dua parameter: nod baharu untuk dimasukkan dan nod rujukan (iaitu nod di mana nod baharu akan dimasukkan).

Tutorial JavaScript: Bagaimana untuk mendapatkan kod status HTTP, contoh kod khusus diperlukan: Dalam pembangunan web, interaksi data dengan pelayan sering terlibat. Apabila berkomunikasi dengan pelayan, kami selalunya perlu mendapatkan kod status HTTP yang dikembalikan untuk menentukan sama ada operasi itu berjaya dan melaksanakan pemprosesan yang sepadan berdasarkan kod status yang berbeza. Artikel ini akan mengajar anda cara menggunakan JavaScript untuk mendapatkan kod status HTTP dan menyediakan beberapa contoh kod praktikal. Menggunakan XMLHttpRequest

JavaScript ialah bahasa pengaturcaraan yang digunakan secara meluas dalam pembangunan web, manakala WebSocket ialah protokol rangkaian yang digunakan untuk komunikasi masa nyata. Menggabungkan fungsi berkuasa kedua-duanya, kami boleh mencipta sistem pemprosesan imej masa nyata yang cekap. Artikel ini akan memperkenalkan cara untuk melaksanakan sistem ini menggunakan JavaScript dan WebSocket, dan memberikan contoh kod khusus. Pertama, kita perlu menjelaskan keperluan dan matlamat sistem pemprosesan imej masa nyata. Katakan kita mempunyai peranti kamera yang boleh mengumpul data imej masa nyata
