世界上最短的數(shù)字判斷js代碼
我們知道JavaScript提供了typeof運算符,因此最容易想到的是用typeof來判斷是否是number類型
function isNumber(obj) {
return typeof obj === 'number'
}
這個函數(shù)對于整數(shù)和浮點數(shù)都沒有問題,但對于NaN值也返回true這讓人感到不爽,畢竟用isNumber判斷通過后誰也不會用NaN去做算術(shù)運算。
那改進一下,用Object.prototype.toString試試
function isNumber(obj) {
return Object.prototype.toString.call(obj) === '[object Number]'
}
和typeof判斷一樣,對于NaN也返回true,代碼量還大了,這不是想要的結(jié)果。toString.call方式判斷數(shù)組(Array)可行,數(shù)字則力不從心了。
再改進下,NaN值用isNaN函數(shù)來對付
function isNumber(obj) {
return typeof obj === 'number' && !isNaN(obj)
}
這次,如果傳入的是非數(shù)字(NaN或者可轉(zhuǎn)成NaN的值)就返回false了
function isNumber(obj) {
return typeof obj === 'number' && !isNaN(obj)
}
isNumber(1) // true
isNumber(1.2) // true
isNumber(NaN) // false
isNumber( parseInt('a') ) // false
嗯,這個isNumber不錯了,但還有一個等價的,用isFinite來判斷
function isNumber(obj) {
return typeof obj === 'number' && isFinite(obj)
}
到現(xiàn)在,最短代碼的數(shù)字判斷是此文提到的第三個使用isNaN函數(shù)的。下面隆重推出世界上最短的數(shù)字判斷代碼
function isNumber(obj) {
return obj === +obj
}
對于整數(shù),浮點數(shù)返回true,對于NaN或可轉(zhuǎn)成NaN的值返回false。
沒看懂是嗎? 咕~~(╯﹏╰)
園友說這還不是世界上最短判斷數(shù)字代碼,參數(shù)obj可以改成一個字符的。(⊙o⊙)你是對的。
舉一反三,類似的利用JS動態(tài)語言特性(運算符運算時內(nèi)部自動類型轉(zhuǎn)換)最短的判斷還有
// 判斷字符串
function isString(obj) {
return obj === obj+''
}
// 判斷布爾類型
function isBoolean(obj) {
return obj === !!obj
}
總結(jié)
以上所述是小編給大家介紹的世界上最短的數(shù)字判斷js代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!
相關(guān)文章
解決layui數(shù)據(jù)表格table的橫向滾動條顯示問題
今天小編就為大家分享一篇解決layui數(shù)據(jù)表格table的橫向滾動條顯示問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
基于JavaScript實現(xiàn)動態(tài)創(chuàng)建表格和增加表格行數(shù)
這篇文章主要介紹了基于JavaScript實現(xiàn)動態(tài)創(chuàng)建表格和增加表格行數(shù)的相關(guān)資料,需要的朋友可以參考下2015-12-12
有關(guān)文件上傳 非ajax提交 得到后臺數(shù)據(jù)問題
本文給大家介紹關(guān)于文件上傳非ajax提交得到后臺數(shù)據(jù)的問題我們該怎么處理呢?下文給大家介紹的非常詳細,感興趣的朋友一起看看吧2016-10-10
TypeScript裝飾器與反射元數(shù)據(jù)實例詳解
TypeScript的裝飾器為我們提供了一種強大的工具,可以在運行時改變類的行為,通過理解裝飾器的工作原理,我們可以創(chuàng)造更加強大、靈活且易于維護的應用,這篇文章主要介紹了TypeScript裝飾器與反射元數(shù)據(jù),需要的朋友可以參考下2023-09-09

