2. JS数据类型检测_封装一个数据类型检测的方法库

JavaScript019

2. JS数据类型检测_封装一个数据类型检测的方法库,第1张

JS中的数据类型分为三大类:

数据类型检测四种方式

语法: typeof [value]

基于 typeof检测结果

@优势

使用方便,所以在真实项目中,我们也会大量应用它来检测,尤其是在检测基本类型值(除null之外)和函数类型值的时候,它还是很方便的

@局限性

1、 typeof null =>“object” , 但是null 并不是对象,是空指针对象

2、无法细分当前值是普通对象还是数组对象等, 如: 是正则 还是数组

因为只要是对象数据类型,返回的结果都是"object"

语法: [实例] instanceof [类]

@局限性:

1、不能处理基本数据类型值

2、只要在当前实例的原型链( proto )中出现过的类,检测结果都是true(用户可能会手动修改原型链的指向:example.proto 或者 在类的继承中 等情况)

@原理

在类的原型上一般都会带有CONSTRUCTOR属性,存储当前类本身,我们也是利用这一点,获取某实例的CONSTRUCTOR属性值,验证是否为所属的类,从而进行数据类型检测

@局限性

可以去随意修改对应的constructor值或者是手动给ary增加一个私有的constructor属性等

"[object 所属类]" ,例如:"[object Array]"...

**所有的数据类型上都有toString方法,只有Object原型上的toString是检测当前实例所属类的详细信息的,其它原型的方法仅仅是转换为字符串

@原理

1.首先基于原型链查找机制,找到Object.prototype.toString

2.把找到的方法执行,方法中的this ->obj

3.方法内部把this(obj)的所属类信息输出

=>方法执行,方法中的this是谁,就是检测谁的所属类信息

@优势

所有数据类型隶属的类信息检测的一清二楚

String/Boolean/Null/Undefined/Symbol/Object/Array/RegExp/Date/Math/Function...

结合每个方法,属性的优缺点,我们来封装一个简单的检测数据类型库:

1、typeof 操作符

typeof 目前能返回string,number,boolean,unfined,object,function,symbol,bigint,这八种判断类型。使用方式:typeof(表达式)和typeof 变量名,具体判断如下:

特别注意数组array的typeof 操作符判断

2、instanceof

A instanceof B 可以判断A是不是B的实例,返回一个布尔值,由构造类型判断出数据类型,目前支持数组,对象,date,function类型。

注: instanceof 后面一定要是对象类型,大小写不能写错!!!

亲测: Symbol is not a constructor

3、Object.prototype.toString.call()

通过Object下的toString.call()方法来判断,目前是最为可靠的类型检测手段,它会将当前对象转换为字符串并输出。但它也不是完美的,它无法检测用户自定义类型。 因为Object.prototype是不知道用户会创造什么类型的, 它只能检测ECMA标准中的那些 内置类型

注意, 这里的Object和function判断打印都是[object Object]。使用Object.prototype.toString.call判断Symbol报错。

4、contructor

依据 对象 的contructor判断,返回一个布尔值。

注: ===后面一定要是对象类型,大写且不能写错!!!

检测简单的数据类型的方法

typeof方法用于检测简单的数据类型如typeof 12

instanceof的实例方法检测如[] instanceof Array // true

arr.constructor == Array判断arr的构造函数是否为数组,如果是则arr是数组

Array.isArray([])判断是否是数组

精确判断数据类型Object.prototype.toString.call(arr)