JS數(shù)據(jù)類型判斷的9種方式總結(jié)
前言
JS 的數(shù)據(jù)類型檢測是一道經(jīng)典的八股文面試題。相信大家都能條件反射的回答出 4 種方法:typeof、constructor、instanceof 和 Object.prototype.toString,并且對它們各自的優(yōu)缺點(diǎn)也是張口就來。
本文對這些方法做了簡單歸納,同時(shí)又補(bǔ)充了其他 5 種和數(shù)據(jù)類型檢測有關(guān)的方法,供諸君食用。
typeof:檢測基礎(chǔ)數(shù)據(jù)類型和函數(shù)很好用
typeof 應(yīng)該是我學(xué)習(xí)到的第一個 JS 的方法,也是使用頻率最高的一個用來檢測數(shù)據(jù)類型的方法。
它能準(zhǔn)確判斷出的數(shù)據(jù)類型有:Number,String,Boolean,Undefined,Symbol,BigInt,F(xiàn)unction。
它的缺點(diǎn)就是不能準(zhǔn)確判斷 null 的類型,而是返回 “object”。對于數(shù)組,日期,普通對象等數(shù)據(jù),統(tǒng)一返回 “object”。
所以在判斷基本數(shù)據(jù)類型(除了 null)和函數(shù)類型時(shí),都會使用它。
constructor:返回實(shí)例對象的構(gòu)造函數(shù)
學(xué)習(xí) JS 到面向?qū)ο蟮碾A段時(shí),會學(xué)到 JS 的原型鏈和原型對象,會學(xué)到通過 new 一個構(gòu)造函數(shù),來創(chuàng)建實(shí)例對象。
構(gòu)造函數(shù)的原型對象上會有一個 constructor 屬性,指向了構(gòu)造函數(shù)自身,所以實(shí)例對象通過原型鏈訪問 constructor 屬性,就能找到自己的構(gòu)造函數(shù),也就是自己的類型了。
它的本意是用來標(biāo)識自己的構(gòu)造函數(shù),卻臨時(shí)拉來當(dāng)壯丁,用來判斷數(shù)據(jù)類型,當(dāng)然也存在一定的風(fēng)險(xiǎn):
- null,undefined 沒有構(gòu)造函數(shù),自然也就訪問不到該屬性,因此不能使用此屬性來判斷
- constructor 可以被改寫,所以不一定準(zhǔn)確
來看幾個例子:
console.log((1).constructor === Number) // true ? console.log([1, 2, 3].constructor === Array) // true ? console.log(undefined.constructor === Array) // 報(bào)錯
在平時(shí)寫代碼時(shí),基本上不會用它來做數(shù)據(jù)類型的檢測。
instanceof:沿著原型鏈去找
它和 constructor 一樣,也是臨時(shí)拉來當(dāng)壯丁。它的作用是檢測實(shí)例對象是不是屬于某個構(gòu)造函數(shù),可以用來做數(shù)據(jù)類型的檢測。
術(shù)業(yè)有專攻,所以它也有缺點(diǎn):
- 不能檢測基本數(shù)據(jù)類型
- 原型鏈可能被修改,導(dǎo)致檢測結(jié)果不準(zhǔn)確
- 只要能在原型鏈上找到構(gòu)造函數(shù),就返回 true,所以類型可能不準(zhǔn)確
來看幾個例子:
console.log(1 instanceof Number) // false ? console.log([] instanceof Array) // true ? console.log([] instanceof Object) // true
實(shí)際中 instanceof 也很少用。
Object.prototype.toString:是個大拿
看名字它是用來將一個值轉(zhuǎn)為字符串的,但其實(shí)并不是,它是一個專門檢測數(shù)據(jù)類型的方法。
它返回的值是一個形如 [object Object] 的字符串,比如:
console.log(toString.call('123')) // [object String]
console.log(toString.call(null)) // [object Null]
console.log(toString.call(true)) // [object Boolean]
console.log(toString.call({})) // [object Object]
console.log(toString.call([])) // [object Array]
console.log(toString.call(function(){})) // [object Function]
console.log(toString.call(new Map)) // [object Map]
console.log(toString.call(new WeakSet)) // [object WeakSet]通常會編寫一個函數(shù),對返回的字符串從第8位做一個截取,截取到倒數(shù)第一位,再去做類型比較。
Symbol.toStringTag:自定義類型
上面的 Object.prototype.toString 方法,之所以對不同的數(shù)據(jù)類型,返回不同的標(biāo)識字符串,就是因?yàn)?Symbol.toStringTag 。
Symbol.toStringTag 是一個內(nèi)置符號屬性,它的值是一個字符串,用于表示一個對象的默認(rèn)描述,也就是調(diào)用 Object.prototype.toString 會返回的內(nèi)容,比如:
let obj = {}
obj[Symbol.toStringTag] = 'ABC'
console.log(Object.prototype.toString.call(obj)) // [object ABC]對于自定義對象,調(diào)用上面的方法,都只會返回 [object Object]。此時(shí)就可以使用 Symbol.toStringTag 來指定一個確定的類型了,比如:
class Person{
get[Symbol.toStringTag](){
return 'Person'
}
}
let person = new Person()
?
console.log(Object.prototype.toString.call(person)) // [object Person]Object.prototype.isPrototypeOf:和 instanceof 類似
isPrototypeOf 和 instanceof 類似,都是基于原型鏈和原型對象去做判斷的。它用來檢查一個對象是否存在于另一個對象的原型鏈上。
function Person() {
}
?
let person = new Person()
?
console.log(Person.prototype.isPrototypeOf(person))Array.isArray:專業(yè)檢測數(shù)組三十年
起初以為它是 ES6 提供的新方法,后來得知其實(shí)屬于 ES 5.1 規(guī)范。
看名字就知道,它是專門用于檢測數(shù)組類型的,該方法的命名真實(shí)言簡意賅。
Array.isArray([]) // true
Number.isNaN
這個方法就是真的屬于 ES6 標(biāo)準(zhǔn)了。
我們知道,JS 中有一個特殊的“數(shù)字” NaN,表示 not a number,不是一個數(shù)字,但它卻歸屬于數(shù)字類型:
console.log(typeof NaN) // 'number'
NaN 用于表示不是一個數(shù)字,它不等于任何值,包括它本身。在 ES6 之前,windows 對象提供了一個全局方法 isNaN,用于判斷一個數(shù)字是不是 NaN:
isNaN(10) // false
isNaN('abc') // true
isNaN(NaN) // true可以發(fā)現(xiàn),isNaN 對于字符串的檢測結(jié)果也是 NaN。但這其實(shí)并不嚴(yán)謹(jǐn),它對要判斷的數(shù)據(jù)做了一個隱式類型轉(zhuǎn)換,先轉(zhuǎn)為數(shù)字再進(jìn)行判斷。而NaN 的檢測應(yīng)該僅限于數(shù)字類型,所以 ES6 提供了 Number.isNaN 方法:
Number.isNaN(NaN) // true
Number.isNaN('123') // false它能判斷一個值是否嚴(yán)格等于NaN。
等比較:與固定值進(jìn)行比較
直接通過與一個特定的值進(jìn)行比較,從而判斷數(shù)據(jù)的類型,比如:
let value = null console.log(value === null) // true ? // 同時(shí)判斷一個值是 undefined 或者 null let value console.log(value == null) // true
總結(jié)
本文整理了 JS 中常用的判斷數(shù)據(jù)類型的方法,其中 typeof 和 Object.prototype.toString 使用場景是最多的,對一些特殊的數(shù)據(jù)類型,比如 null,NaN,自定義類型,可以選擇其他的方式去進(jìn)行判斷,做到靈活運(yùn)用。
到此這篇關(guān)于JS數(shù)據(jù)類型判斷的9種方式的文章就介紹到這了,更多相關(guān)JS數(shù)據(jù)類型判斷內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JS中將多個逗號替換為一個逗號的實(shí)現(xiàn)代碼
這篇文章主要介紹了JS中將多個逗號替換為一個逗號的實(shí)現(xiàn)代碼,需要的朋友可以參考下2017-06-06
echarts同一頁面中四個圖表切換的js數(shù)據(jù)交互方法示例
這篇文章主要給大家介紹了關(guān)于echarts同一頁面中四個圖表切換的js數(shù)據(jù)交互的相關(guān)資料,文中給出了完整的示例代碼供大家參考學(xué)習(xí),對大家的學(xué)習(xí)或者工作具有一定的幫助,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-07-07
寫出更好的JavaScript程序之undefined篇(中)
前一篇我介紹了幾種廣為使用的利用undefined這個概念值的辦法,這一篇我會介紹一些不太常見的辦法,其中還包括一個很巧妙的,我個人覺得很值得推廣的辦法。2009-11-11
利用NodeJS和PhantomJS抓取網(wǎng)站頁面信息以及網(wǎng)站截圖
這篇文章主要介紹了利用NodeJS和PhantomJS抓取網(wǎng)站頁面信息以及網(wǎng)站截圖的方法,提供實(shí)例代碼供大家參考2013-11-11
IE6/7/8中Option元素未設(shè)value時(shí)Select將獲取空字符串
可以看到當(dāng)忘記寫option的value時(shí)這些現(xiàn)代瀏覽器都會盡量返回正確的(客戶端程序員想要的)結(jié)果value,其容錯性比IE6/7/8做的更好。2011-04-04
JavaScript實(shí)現(xiàn)猜數(shù)字游戲
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)猜數(shù)字游戲,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-05-05
微信小程序?qū)崿F(xiàn)點(diǎn)擊卡片 翻轉(zhuǎn)效果
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)點(diǎn)擊卡片 翻轉(zhuǎn)效果本文通過實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-09-09

