js数据类型检测

1、typeof

console.log(typeof null) 输出为Object

console.log(typeof  [ ])输出为Object

console.log(typeof function(){})输出为function

所以说,typeof对于基础类型来说,除了null判定为object类型,其他的都能显示正确类型,对于引用类型来说,除了function判定为function类型,其他的都是显示Object类型。

2、instanceof

console.log( 2 instanceof number)输出false

console.log([ ] instanceof Array)输出为true

console.log(function(){} instanceof Function)输出为true

console.log({} instanceof Object)输出为true

所以说,instanceof可以准确的判断对象类型,因为他是通过判断对象的原型链中是否能找到类型的prototype,但是不能判断基础数据类型

3、constructor

console.log((2).constructor === number) //true

console.log((true).constructor === boolean) //true

console.log(([ ]).constructor === Array)//true

constructor可以正确的判断类型,但是有一个问题,如果更改一个对象的原型,那么这个方法就会变得不可靠。

4、Object.prototype.toString.call()

对于对象类型,直接使用Object.prototype.toString({})就可以得出类型,如果是基础类型,则使用Object.prototype.toString.call('123')来判断类型,这个方法甚至可以把window和document区分开来。

 

posted @ 2022-02-09 15:54  大坏坏狼  阅读(42)  评论(0编辑  收藏  举报