JS 判断一个值是什么类型有哪些方法?

  • Post author:
  • Post category:其他




typeof 运算符

  • 在 JavaScript 里使用 typeof 来判断数据类型,只能区分基本类型,即“Number”,”String”,”undefined”,”Boolean”,”Object”,“Function”,“symbol”(ES6 新增)七种
  • 对于数组、null、对象来说,其关系错综复杂,使用 typeof 都会统一返回“object”字符串



语法

typeof operand 
typeof(operand)



缺点

要想区别对象 、 数组 、 函数 单纯使用 typeof 是不行的,JavaScript 中, 通过Object.prototype.toString 方法,判断某个对象值属于哪种内置类型



toString.call 方法判断

  • call() 方法使用一个指定的 this 值和单独给出的一个或多个参数来调用一个函数



解释

call() 方法 改变当前this指向 call 方法中的第一个参数 为this指向对象

注意 toString.call([1,2]) != [1,2].toString

重写了 toString 方法,应使用该方法

Object.prototype.toString.call()

使用时 建议封装一下 挂载在原型上

let arr=[1,2];
//通过 call 指定 arr 数组为 Object.prototype 对象中的 toString 方法
Object.prototype.toString.call(arr) //'[object Array]'



简单封装

function getType(value){
        let type = typeof value;
        if(type !== 'object') return type ;
        return Object.prototype.toString.call(value).replace(/^\[object (\S+)\]$/, '$1');
    }



instanceof 运算符

  • instanceof 运算符用于检测构造函数的 prototype 属性是否出现在某个实例对象的原型链上。



解释

这句话的意思就是 instanceof 用来判断某一个对象是否是通过某一个构造函数创建的

判断 a 是否是 A 类的实例



语法

object instanceof constructor

(()=>{
	var date = new Date()
	console.log(date instanceof Date) // true
})()



版权声明:本文为qq_45443060原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。