1. 程式人生 > >Object.prototype.toString.call()方法

Object.prototype.toString.call()方法

.com block new 聯系 uil log pan 自定義 typeof

在JavaScript裏使用typeof判斷數據類型,只能區分基本類型,即:number、string、undefined、boolean、object
對於null、array、function、object來說,使用typeof都會統一返回object字符串。
要想區分對象、數組、函數、單純使用typeof是不行的。在JS中,可以通過Object.prototype.toString方法,判斷某個對象之屬於哪種內置類型。
分為null、string、boolean、number、undefined、array、function、object、date、math。

1. 判斷基本類型

Object.prototype.toString.call(null); // "[object Null]"
Object.prototype.toString.call(undefined); // "[object Undefined]"
Object.prototype.toString.call(“abc”);// "[object String]"
Object.prototype.toString.call(123);// "[object Number]"
Object.prototype.toString.call(true);// "[object Boolean]"

2. 判斷原生引用類型

**函數類型**
Function fn(){
  console.log(“test”);
}
Object.prototype.toString.call(fn); // "[object Function]"
**日期類型**
var date = new Date();
Object.prototype.toString.call(date); // "[object Date]"
**數組類型**
var arr = [1,2,3];
Object.prototype.toString.call(arr); // "[object Array]"
**正則表達式**
var reg = /[hbc]at/gi;
Object.prototype.toString.call(reg); // "[object RegExp]"
**自定義類型**
function Person(name, age) {
    this.name = name;
    this.age = age;
}
var person = new Person("Rose", 18);
Object.prototype.toString.call(arr); // "[object Object]"

無法區分自定義對象類型,自定義類型可以采用instanceof區分

console.log(person instanceof Person); // true

3.判斷原生JSON對象

var isNativeJSON = window.JSON && Object.prototype.toString.call(JSON);
console.log(isNativeJSON);//輸出結果為”[object JSON]”說明JSON是原生的,否則不是;


作者:yinxmm
鏈接:https://www.jianshu.com/p/4c92eb5eb361
來源:簡書
簡書著作權歸作者所有,任何形式的轉載都請聯系作者獲得授權並註明出處。

Object.prototype.toString.call()方法