js数据类型判断

js数据类型的判断


四种方法:

typeof,instanceof,constructor,Object.prototype.toString.call().

1.typeof

console.log( typeof 100 //number typeof 'abc' //string typeof false //boolean typeof undefined //undefined typeof null //object typeof [1,2,3] //object typeof {a:1,b:2,c:3} //object typeof function(){console.log('aaa')} //function typeof new Date() //object typeof /^[a-zA-Z]{5,20}$/, //object typeof new Error() //object typeof new Number(100) //object typeof new String('abc') //String typeof new Boolean(true) //boolean );

基本数据类型中:Number,String,Boolean,Undefined以及引用数据类型中Function,可以使用typeof检测数据类型,分别返回对应的数据类型,分别返回对应的数据类型小写字符。
另外:用typeof检测构造函数创建的Number,String,Boolean都返回object,基本数据类型中:Null。引用数据类型中的:Array,Object,Date,RegExp。不可以用typeof检测。都会返回小写的object。

2.instanceof

除了使用typeof来判断,还可以使用instanceof。instanceof运算符需要指定一个构造函数或者说指定一个特定的类型,它用来判断这个构造函数的原型是否在给定对象的原型链上。

console.log( 100 instanceof Number, //false 'dsfsf' instanceof String, //false false instanceof Boolean, //fasle undefined instanceof Object, //false null instanceof Object, //false [1,2,3] instanceof Array, //true {a:1,b:2,c:3} instanceof Object, //true function(){console.log('aaa');} instanceof Function, //true new Date() instanceof Date, //true /^[a-zA-Z]{5,20}$/ instanceof RegExp, //true new Error() instanceof Error //true )

基本数据类型中:Number,String,Boolean。字面量值不可以用instanceof检测,但是构造函数创建的值可以,如下:

var num = new Number(123); var str = new String('dsfsf'); var boolean = new Boolean(false);

还需要注意null和undefined都返回了false,这是因为它们的类型就是自己本身,并不是Object创建的,所以返回了false

3.constructor

constructor是prototype对象上的属性,指向构造函数。根据实例对象寻找属性的顺序,若示例对象上没有实例属性或方法时,就去原型链上寻找,因此,实例对象也是能使用constructor属性的。
如果输出一个类型的实例的constructor,就如下所示:

console.log(new Number(123).constructor) //f Number() {[native code]}

可以看到它指向了number的构造函数,因此,可以使用num.constructor == Number来判断一个变量是不是Number类型

var num = 123; var str = 'abcded' var bool = true; var arr = [1,2,3,4]; var json = {name:"wenzi",age:25}; var func = function(){console.log('this is function');} var nul = null; var date = new Date(); var reg = /^[a-zA-Z]{5,20}$/; var error = new Error(); function Person(){ } var tom = new Person(); //undefined和null没有constructor属性 console.log( tom.constructor == Person, num.constructor == Number, str.constructor == String, bool.constructor == Boolean, arr.constructor == Array, json.constructor = Object, func.constructor == Function, date.constructor == Date, reg.constructor == RegExp, error.constructor == Error ) //所有结果均为true

除了undefined和null之外,其他类型都可以通过constructor属性来判断类型。

4.使用Object.prototype.toString.call()检测对象类型

可以通过toString()来获取每个对象的类型。为了每个对象都能通过Object.prototype.toString()来检测,需要以Function.prototype.call()或者Function.prototype.apply()的形式来调用,传递要检查的对象作为第一个参数称为thisArg。

var toString = Object.prototype.toString; toString.call(123); //"[object Number]" toString.call('abcdef'); //"[object String]" toString.call(true); //"[object Boolean]" toString.call([1, 2, 3, 4]); //"[object Array]" toString.call({name:'wenzi', age:25}); //"[object Object]" toString.call(function(){ console.log('this is function'); }); //"[object Function]" toString.call(undefined); //"[object Undefined]" toString.call(null); //"[object Null]" toString.call(new Date()); //"[object Date]" toString.call(/^[a-zA-Z]{5,20}$/); //"[object RegExp]" toString.call(new Error()); //"[object Error]"

这样可以看到使用Object.prototype.toString.call()的方式来判断一个变量的类型是最准确的方式


__EOF__

本文作者HuangJiaZ
本文链接https://www.cnblogs.com/HuangJiaZ/p/16660867.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   HuangJiaZ  阅读(30)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
点击右上角即可分享
微信分享提示