码迷,mamicode.com
首页 > 其他好文 > 详细

Object.prototype.toString.call(obj)检测数据类型

时间:2019-03-20 17:30:34      阅读:131      评论:0      收藏:0      [点我收藏+]

标签:type   html   let   style   重写   对象   区分   纯粹   原型链   

typeof bar==‘object‘ 不能确切判断数据是一个‘纯粹’的对象 Array null的结果都是object

比较好的方法是:

Object.prototype.toString.call(bar)==‘[object Object]‘;

使用以上方法可以很好的区分各种类型:

console.log(Object.prototype.toString.call(""));//[object String]
console.log(Object.prototype.toString.call(12));//[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({}));//[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 Person(){};
console.log(Object.prototype.toString.call(new Person));//[object Object]

toString()方法返回这个的对象的字符串

为什么不用obj.toString(),obj.toString()的结果与object.prototype.toString.call(obj);的结果不一样,为什么呢?

这是因为toString为Object的原型方法,而Array funciton等类型作为Object的实例,都重写了toString方法。不同的对象类型调用toString方法时,调用的是重写后的toStirng方法。

可以验证一下:

let arr=[2,3,4];
console.log(Array.prototype.toString.call(arr));//‘[object,Array]‘
console.log(Array.prototype.hasOwnProperty(‘toString‘));//true  console.log(arr.toString());//2,3,4 delete Array.prototype.toString console.log(arr.toString());//‘[object,Array]‘

删除了Array的toString方法后,同样再采用arr.toString()方法调用时,不再有屏蔽Object源性方法的实例方法,因此沿着原型链,arr调用了Object的toString方法,返回了和Array.prototype.toString.call(arr);相同的结果。

 

 

 

 

 

 

参考:https://www.cnblogs.com/youhong/p/6209054.html

Object.prototype.toString.call(obj)检测数据类型

标签:type   html   let   style   重写   对象   区分   纯粹   原型链   

原文地址:https://www.cnblogs.com/xiaofenguo/p/10566065.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!