JavaScript中常見(jiàn)的數(shù)據(jù)類型判斷方法小結(jié)
一、typeof
typeof運(yùn)算符返回一個(gè)字符串, 表示操作數(shù)的類型, 使用語(yǔ)法:typeof <操作數(shù)>
1.1 規(guī)則
下表, 是 typeof 針對(duì)不同數(shù)據(jù)類型, 返回的結(jié)果值
| 類型 | 結(jié)果 |
|---|---|
Boolean | "boolean" |
String | "string" |
Number | "number" |
BigInt | "bigint" |
Symbol | "symbol" |
Undefined | "undefined" |
Null | "object" |
Function (在 class 也是函數(shù)) | "function" |
| 其他任何對(duì)象 | "object" |
示例代碼如下:
console.log(typeof true) // boolean
console.log(typeof '123') // string
console.log(typeof 11111) // number
console.log(typeof Math.LN2) // number
console.log(typeof Infinity) // number
console.log(typeof NaN) // number
console.log(typeof BigInt(11111)) // bigint
console.log(typeof Symbol(1111)) // symbol
console.log(typeof undefined) // undefined
console.log(typeof null) // object
console.log(typeof (() => {})) // function
console.log(typeof class {}) // function
console.log(typeof {}) // object
console.log(typeof []) // object
console.log(typeof /abc/) // object
console.log(typeof new Date()) // object
console.log(typeof new Promise(() => {})) // object1.2 為什么「typeof null」等于「object」
// JavaScript 誕生以來(lái)便如此 typeof null === "object";
- 在
JS中typeof null的結(jié)果為"object", 這是從JS的第一版遺留至今的一個(gè)bug - 在
JS最初的實(shí)現(xiàn)中,JS中的值是由一個(gè)表示類型的標(biāo)簽和實(shí)際數(shù)據(jù)值表示的, 對(duì)象的類型標(biāo)簽是0, 由于null代表的是空指針, 在大多數(shù)平臺(tái)下值表示為0x00, 因此,null的類型標(biāo)簽是0, 因此typeof null也就返回了object - 當(dāng)然針對(duì)這個(gè)
BUG曾有一個(gè)ECMAScript的修復(fù)提案, 但是被拒絕了, 原因是遺留代碼太多了, 如果修改的話影響太廣, 不如繼續(xù)將錯(cuò)就錯(cuò)當(dāng)個(gè)和事老
1.3 為什么「typeof (() => {})」等于 「function」
首先我們需要了解一個(gè)小知識(shí), 函數(shù)是什么? 為什么被調(diào)用?
function 實(shí)際上是 object 的一個(gè) 子類型, 更深點(diǎn)說(shuō), 函數(shù)是一個(gè)可以被調(diào)用的對(duì)象; 那么它為什么能夠被調(diào)用呢? 那是因?yàn)槠鋬?nèi)部實(shí)現(xiàn)了 [[Call]] 方法, 當(dāng)函數(shù)對(duì)象被調(diào)用時(shí)會(huì)執(zhí)行內(nèi)部方法 [[call]]
那么回到正題, 為什么 typeof (() => {}) 會(huì)返回 function? 這里主要還是要看 ES6 中 typeof 是如何區(qū)分函數(shù)和對(duì)象類型的:
- 一個(gè)對(duì)象如果沒(méi)有實(shí)現(xiàn)
[[Call]]內(nèi)部方法, 那么它就返回object - 一個(gè)對(duì)象如果實(shí)現(xiàn)了
[[Call]]內(nèi)部方法, 那么它就返回function
1.4 注意事項(xiàng)
- 所有使用
構(gòu)造函數(shù)創(chuàng)建的數(shù)據(jù),typeof都會(huì)返回object或function
const str = new String("String");
const num = new Number(100);
typeof str; // "object"
typeof num; // "object"
const func = new Function();
typeof func; // "function"typeof操作符的優(yōu)先級(jí)高于加法 (+)等二進(jìn)制操作符, 因此, 必要時(shí)候記得用括號(hào)
// 括號(hào)有無(wú)將決定表達(dá)式的類型。 const someData = 99; typeof someData + " Wisen"; // "number Wisen" typeof (someData + " Wisen"); // "string"
二、instanceof & isPrototypeOf()
在 JS 中我們有 兩種 方式可以判斷 原型 是否存在于某個(gè) 實(shí)例 的 原型鏈 上, 通過(guò)這種判斷就可以幫助我們, 確定 引用數(shù)據(jù) 的具體類型; 需要注意的是該方法 只能用于判斷引用數(shù)據(jù), 無(wú)法判斷 基本數(shù)據(jù) 類型
2.1 instanceof
介紹:
instanceof運(yùn)算符用于檢測(cè)構(gòu)造函數(shù)的prototype屬性是否出現(xiàn)在某個(gè)實(shí)例對(duì)象的原型鏈上語(yǔ)法:
實(shí)例對(duì)象 instanceof 構(gòu)造函數(shù), 返回一個(gè)Boolean值示例:
function Car(make, model, year) {
this.make = make;
this.model = model;
this.year = year;
}
const auto = new Car('Honda', 'Accord', 1998);
auto instanceof Car // Car.prototype 是否在 auto 原型鏈上, true
auto instanceof Object // Object.prototype 是否在 auto 原型鏈上, true2.2 Object.prototype.isPrototypeOf()
介紹:
isPrototypeOf()方法用于檢查一個(gè)對(duì)象是否存在于另一個(gè)對(duì)象的原型鏈中語(yǔ)法:
原型.isPrototypeOf(實(shí)例), 返回一個(gè)布爾值示例:
function Car() {}
const auto = new Car();
Car.prototype.isPrototypeOf(auto) // Car.prototype 是否在 auto 原型鏈上, true
Object.prototype.isPrototypeOf(auto) // Object.prototype 是否在 auto 原型鏈上, true三、根據(jù)「constructor」進(jìn)行判斷
constructor 判斷方法跟 instanceof 相似, 如下圖是 原型、實(shí)例、構(gòu)造函數(shù) 之間的一個(gè)關(guān)系圖, 從圖可知, 在 實(shí)例對(duì)象的原型 中存在 constructor 指向 構(gòu)造函數(shù), 那么借用這個(gè)特性我們可以用于判斷 數(shù)據(jù) 類型

function Car() {}
const auto = new Car();
auto.constructor === Car // true不同于 instanceof, 通過(guò)該方式既可以處理 引用數(shù)據(jù)、又能夠處理 基本數(shù)據(jù)
(123).constructor === Number // true
(true).constructor === Boolean // true
('bar').constructor === String // true不同于 instanceof, 不能判斷 對(duì)象父類
class A {}
class B extends A {}
const b = new B()
b.constructor === B // true
b.constructor === A // false
b instanceof B // true
b instanceof A // true注意: null 和 undefined 沒(méi)有 constructor, 所以它是無(wú)法檢測(cè) Null undefined
四、Object.prototype.toString.call()
Object.prototype.toString() 方法返回一個(gè)表示該對(duì)象的字符串, 該字符串格式為 "[object Type]", 這里的 Type 就是對(duì)象的類型
const toString = Object.prototype.toString; toString.call(111); // [object Number] toString.call(null); // [object Null] toString.call(undefined); // [object Undefined] toString.call(Math); // [object Math] toString.call(new Date()); // [object Date] toString.call(new String()); // [object String]
注意: 對(duì)于自定義構(gòu)造函數(shù)實(shí)例化出來(lái)的對(duì)象, 返回的是 [object Object]
const toString = Object.prototype.toString;
function Bar(){}
toString.call(new Bar()); // [object Object]默認(rèn), 如果一個(gè)對(duì)象有 Symbol.toStringTag 屬性并且該屬性值是個(gè)字符串, 那么這個(gè)屬性值, 會(huì)被用作 Object.prototype.toString() 返回內(nèi)容的 Type 值進(jìn)行展示
const toString = Object.prototype.toString;
const obj = {
[Symbol.toStringTag]: 'Bar'
}
toString.call(obj) // [object Bar]補(bǔ)充: 一個(gè)通用方法, 一行代碼獲取 數(shù)據(jù)的類型
const getType = (data) => {
return Object.prototype.toString.call(someType)
.slice(8, -1)
.toLocaleLowerCase()
}五、總結(jié)
| 判斷方法 | 基本類型 | 引用類型 | 父類 | null | undefined |
|---|---|---|---|---|---|
typeof | ? | ? | ? | ? | ? |
instanceof & isPrototypeOf() | ? | ? | ? | ? | ? |
constructor | ? | ? | ? | ? | ? |
Object.prototype.toString.call() | ? | ? | ? | ? | ? |
| 標(biāo)題 |
|---|
typeof適合用于判斷基本類型, 特別的是:Null會(huì)返回object、Function返回function、其余引用類型都返回objectinstanceof & isPrototypeOf()可以用于判斷引用數(shù)據(jù)的類型, 同時(shí)可判斷對(duì)象父類constructor可用于基本類型、引用類型, 但是不可判斷null、undefined, 并且無(wú)法判斷對(duì)象父類Object.prototype.toString.call()萬(wàn)能方法, 對(duì)于JS中所有類型都能夠識(shí)別出來(lái), 唯一不足的可能是無(wú)法判斷對(duì)象父類(但是問(wèn)題不大)
以上就是JavaScript中常見(jiàn)的數(shù)據(jù)類型判斷方法小結(jié)的詳細(xì)內(nèi)容,更多關(guān)于JavaScript 判斷方法的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
動(dòng)態(tài)加載外部javascript文件的函數(shù)代碼分享
動(dòng)態(tài)加載外部javascript文件的函數(shù)代碼分享,做個(gè)記錄備忘,方便查找。2011-07-07
解析javascript系統(tǒng)錯(cuò)誤:-1072896658的解決辦法
問(wèn)題出現(xiàn)在用到ajax的場(chǎng)合。昨天還正常的程序,今天運(yùn)行就有javascript系統(tǒng)錯(cuò)誤:-1072896658的2013-07-07
JS關(guān)于刷新頁(yè)面的相關(guān)總結(jié)
在本篇內(nèi)容中我們給大家整理了關(guān)于JS刷新頁(yè)面的所有相關(guān)知識(shí)點(diǎn)以及整理了相關(guān)的技術(shù)文章,大家可以收藏本頁(yè)面繼續(xù)深入學(xué)習(xí)。2018-05-05
JavaScript在for循環(huán)中綁定事件解決事件參數(shù)不同的情況
響應(yīng)一堆相似的事件,但是每個(gè)事件的參數(shù)都不同,在這種情況下就可以使用JavaScript 在for循環(huán)中綁定事件,下面有個(gè)不錯(cuò)的示例,大家可以參考下2014-01-01
使用javascript實(shí)現(xiàn)ListBox左右全選,單選,多選,全請(qǐng)
使用javascript實(shí)現(xiàn)ListBox左右全選,單選,多選,全請(qǐng)。需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2013-11-11
JavaScript頁(yè)面倒計(jì)時(shí)功能完整示例
這篇文章主要介紹了JavaScript頁(yè)面倒計(jì)時(shí)功能,結(jié)合完整實(shí)例形式分析了javascript計(jì)時(shí)器、時(shí)間運(yùn)算相關(guān)操作技巧,需要的朋友可以參考下2019-05-05
JavaScript中常用的數(shù)組操作方法總結(jié)
這篇文章為大家總結(jié)了一些JavaScript中常用的數(shù)組操作方法,文中通過(guò)示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-07-07
你應(yīng)該了解的JavaScript Array.map()五種用途小結(jié)
大家都知道m(xù)ap() 方法返回一個(gè)新數(shù)組,數(shù)組中的元素為原始數(shù)組元素調(diào)用函數(shù)處理后的值。下面這篇文章主要給大家介紹了關(guān)于JavaScript Array.map()的五種用途,需要的朋友可以參考下2018-11-11
JavaScript實(shí)現(xiàn)QQ聊天室功能
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)QQ聊天室功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-07-07
移動(dòng)端刮刮樂(lè)的實(shí)現(xiàn)方式(js+HTML5)
本篇文章主要介紹了移動(dòng)端刮刮樂(lè)的實(shí)現(xiàn)方法以及實(shí)現(xiàn)代碼。具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-03-03

