js中isNaN和Number.isNaN的區別


isNaN

當我們向isNaN傳遞一個參數,它的本意是通過Number()方法嘗試將這參數轉換成Number類型,如果成功返回false,如果失敗返回true。

所以isNaN只是判斷傳入的參數是否能轉換成數字,並不是嚴格的判斷是否等於NaN。

例子:

Number('測試') //輸出NaN

 因為沒有將“測試”成功轉換成Number類型,所以下面代碼輸出true

console.log(isNaN('測試')) //true

 

Number.isNaN

判斷傳入的參數是否嚴格的等於NaN(也就是 ===)。

那一般在什么情況下會用到Number.isNaN呢?

當兩個變量進行運算時,我們可以使用Number.isNaN來判斷它的值是否為NaN

console.log(Number.isNaN(1/'測試')); //輸出true

 

兩者的區別

Number.isNaN與isNaN最的區別是,Number.isNaN不存在類型轉換的行為。

console.log(isNaN('測試')) //true
console.log(Number.isNaN('測試')) //false

上面代碼中,都是傳入字符串“測試”,但為什么結果不同?原因在於:

isNaN會通過Number方法,試圖將字符串"測試"轉換成Number類型,但轉換失敗了,因為 Number('測試') 的結果為NaN ,所以最后返回true。

而Number.isNaN方法,只是嚴格的判斷傳入的參數是否全等於NaN( '測試' === NaN) ,字符串當然不全等於NaN啦,所以輸出false。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM