ES6结合正则判断js数据类型

ES5:(有重复问题)

typeof 1           ---> ‘number‘
typeof ‘hello‘     ---> ‘string‘
typeof alert       ---> ‘function‘
typeof [1,2,3]     ---> ‘object‘
typeof {a:1,b:2}   ---> ‘object‘
typeof null        ---> ‘object‘
typeof NaN         ---> ‘number‘
typeof undefined   ---> ‘undefined‘
typeof Symbol()    ---> ‘symbol‘

ES6: (修补了问题)

console.log(Object.prototype.toString.call("hello"));//[object String]
console.log(Object.prototype.toString.call(123));//[object Number]
console.log(Object.prototype.toString.call(true));//[object Boolean]
console.log(Object.prototype.toString.call(undefined));//[object Undefined]
console.log(Object.prototype.toString.call(null));//[object Null]
console.log(Object.prototype.toString.call({name: "jerry"}));//[object Object]
console.log(Object.prototype.toString.call(function(){}));//[object Function]
console.log(Object.prototype.toString.call([]));//[object Array]
console.log(Object.prototype.toString.call(new Date));//[object Date]
console.log(Object.prototype.toString.call(/\d/));//[object RegExp]
function foo(){}
console.log(Object.prototype.toString.call(new foo()));//[object Object]

最后ES6结合正则的方式,使用最方便:

const isType = type =>(/^\[object\s(.*)\]$/.exec(Object.prototype.toString.call(type)))[1];isType({}) // ‘Object‘isType([]) // ‘Array‘

注意首字母是大写

.