typeof不好判断null、Array,Object等,自己封装一个类型判断方法,可精确判断

这里参考了jQuery的做法:

var class2type={};	//定义一个对象
var typeArr = "Boolean Number String Function Array Date RegExp Object".split(" ");//将所有的类型放到一个数组
for(var i=0,len=typeArr.length;i<len;i++){
	var name=typeArr[i];
	class2type[ "[object " + name + "]" ] = name;
}

function getType( obj ) {
	return obj == null ?
		String( obj ) :
		class2type[ Object.prototype.toString.call(obj) ] || "undefined";
}


console.log(getType("abc"));//字符串String
console.log(getType(1));//数字Number
console.log(getType(null));//null
console.log(getType(undefined));//undefined
console.log(getType(function(){}));//Function
console.log(getType({}));//Object
console.log(getType(/test/));//RegExp
console.log(getType(true));//Boolean
console.log(getType([]));//Array
console.log(getType(new Date()));//Date

输出:

String
Number
null
undefined
Function
Object
RegExp
Boolean
Array
Date

用这个来判断类型的话,就一目了然。

把typeof输出放到一起,来比对一下就很明显了:

console.log(getType("abc"),"----",typeof "abc");//字符串String
console.log(getType(1),"----",typeof 1);//数字Number
console.log(getType(true),"----",typeof true);//Boolean
console.log(getType(function(){}),"----",typeof function(){});//Function
console.log(getType(null),"----",typeof null);//null
console.log(getType(undefined),"----",typeof undefined);//undefined
console.log(getType({}),"----",typeof {});//Object
console.log(getType(/test/),"----",typeof /test/);//RegExp
console.log(getType([]),"----",typeof []);//Array
console.log(getType(new Date()),"----",typeof new Date());//Date

看输出结果的比较:

String ---- string
Number ---- number
Boolean ---- boolean
Function ---- function
null ---- object
undefined ---- undefined
Object ---- object
RegExp ---- object
Array ---- object
Date ---- object

看结果typeof有几个判断为object的,而封装后却能明显的区分开来!

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

编程界小明哥

请博主喝瓶水,博主持续输出!

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值