一句有趣的JS代码"/>
分享一句有趣的JS代码
难度:中等
我们经常在框架级的源码中看到类似如下的一句代码,比如:
var toStr1 = Function.prototype.call.bind(Object.prototype.toString);
复制代码
在这一句代码中既使用call方法,同时也使用bind方法,乍看之下,有点晕!这到底是想干嘛?
无妨,我们调用看看,传入不同的类型试试,效果如下:
console.log(toStr1({})); // “[object Object]”
console.log(toStr1([])); // “[object Array]”
console.log(toStr1(123)); // “[object Number]”
console.log(toStr1(“abc”)); // “[object String]”
console.log(toStr1(“abc”)); // “[object String]”
console.log(toStr1(new Date));// “[object Date]”
复制代码
从结果中可以看到该方法的主要功能是用于检测对象的类型。但通常类型检测,我们可能更多地看到如下代码实现:
var toStr2 = obj => Object.prototype.toString.call(obj);
console.log(toStr2({})); // “[object Object]”
console.log(toStr2([])); // “[object Array]”
console.log(toStr2(123)); // “[object Number]”
console.log(toStr2(“abc”)); // “[object String]”
更多推荐
分享一句有趣的JS代码
发布评论