在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。
- 判断基本类型
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]”
自定义类型
function Person(name, age) {
this.name = name;
this.age = age;
}
var person = new Person(“Rose”, 18);
Object.prototype.toString.call(person); // “[object Object]”
很明显这种方法不能准确判断person是Person类的实例,而只能用instanceof 操作符来进行判断,如下所示:
console.log(person instanceof Person); // true
<script>
const a = 5
const arr = [1, 2, 3]
console.log(Object.prototype.toString.call(arr))
// class MyArr extends Array { }
// let arr2 = new MyArr();//MyArr为父类,arr2为字类,因此字类会继承父类的一切方法
// //如.push()\.pop()等
// arr2.push(5, 6, 7)
// console.log(arr2 instanceof Array) //返回true
// console.log(Array.isArray(arr2)) //返回true
// console.log(a instanceof Array)
function Person(name, age) {
this.name = name;
this.age = age;
}
var person = new Person("Rose", 18);
console.log(Object.prototype.toString.call(person));//此时输出[object Object]
//即不能判断person是Person类的实例还是原生的Object类型,
//因此需要用到console.log(person instanceof Person); // true
</script>