JavaScript

超轻量级php框架startmvc

详解js类型判断

更新时间:2020-07-10 06:42:01 作者:startmvc
js类型转换中typeof会将null也识别为object,而且返回的类型比少,我们用Object.prototype.toString来实

js类型转换中typeof会将null也识别为object, 而且返回的类型比少,我们用Object.prototype.toString来实现

第一版


function isArray(value){
 return Object.prototype.toString.call(value) === "[object Array]";
}

function isFunction(value){
 return Object.prototype.toString.call(value) === "[object Function]";
}

但是这样写,一个个去判断数组,函数,对象的话很麻烦,比较过程化

第二版

我们想用type(obj)的方式返回对应的类型字符串,因为typeof是小写,所以我们也返回小写的标准


function type(obj){
 // -1 代表截止到倒数一位
 return Object.prototype.toString.call(obj).slice(8,-1).toLowerCase()
}

type([]) // "array"

但是这样每次都需要对判断的类型进行slice和toLowerCase也是比较耗性能的, 而且判断类型只有几种,所以我们可以用对象提前将可能的结果缓存起来

第三版


//将types放外面 而不是放在type函数里面, 利用闭包,优化性能,不用每次判断都声明一次typess
var types = {
 '[object Function]': 'function',
 '[object Number]': 'number',
 ...
}

function type(obj) {
 var str = Object.prototype.toString.call(obj)
 return types[str]
}

当然上面的types我们还可以这样优化


// 参考自jquery源码
var types = {}
当然也可以直接用数组存储
"Boolean Number String Function Array Date RegExp Object Error".split(" ").forEach(function(e,i){
 types [ "[object " + e + "]" ] = e.toLowerCase();
}) ;

判断window对象

利用window对象的window属性等于自身


function isWindow( obj ) {
 // obj !== undefined 是为了防止没传参数的时候后面报错
 // Uncaught TypeError: Cannot read property 'window' of undefined的错误
 
 return obj !== undefined && obj === obj.window;
}

判断是不是dom元素


isElement = function(obj) {
 return !!(obj && obj.nodeType === 1);
}

js 类型判断