Object.prototype.toString.call

 

查了 ecmascript 262 spec 以及 ie6 ,firefox3.5 实验才发现实际和标准还是不完全一样的


利用 Object.prototype.toString.call 得到 [[class]]

 

IE6 6.0.2900.5512

 

Js代码
  1. Object.prototype.toString.call(String.prototype) : [object Object]    
  2. Object.prototype.toString.call(Number.prototype) : [object Number]    
  3. Object.prototype.toString.call(undefined) : [object Object]    
  4. Object.prototype.toString.call(null) : [object Object]    
  5. Object.prototype.toString.call(Boolean.prototype) : [object Boolean]    
  6. Object.prototype.toString.call(Function.prototype) : [object Function]    
  7. Object.prototype.toString.call(Array.prototype) : [object Array]    
  8. Object.prototype.toString.call(Date.prototype) : [object Date]    
  9. Object.prototype.toString.call(RegExp.prototype) : [object RegExp]    
  10. Object.prototype.toString.call(Object.prototype) : [object Object]    
  11. Object.prototype.toString.call(Error.prototype) : [object Object]    
  12. Object.prototype.toString.call(EvalError.prototype) : [object Error]    
  13. Object.prototype.toString.call(Error) : [object Function]    
  14. Object.prototype.toString.call(EvalError) : [object Function]    
  15. Object.prototype.toString.call(/t/) : [object RegExp]   

 

Firefox 3.5.2

 

Js代码
  1. Object.prototype.toString.call(String.prototype) : [object String]   
  2. Object.prototype.toString.call(Number.prototype) : [object Number]   
  3. Object.prototype.toString.call(undefined) : [object Window]   
  4. Object.prototype.toString.call(null) : [object Window]   
  5. Object.prototype.toString.call(Boolean.prototype) : [object Boolean]   
  6. Object.prototype.toString.call(Function.prototype) : [object Function]   
  7. Object.prototype.toString.call(Array.prototype) : [object Array]   
  8. Object.prototype.toString.call(Date.prototype) : [object Date]   
  9. Object.prototype.toString.call(RegExp.prototype) : [object RegExp]   
  10. Object.prototype.toString.call(Object.prototype) : [object Object]   
  11. Object.prototype.toString.call(Error.prototype) : [object Error]   
  12. Object.prototype.toString.call(EvalError.prototype) : [object Error]   
  13. Object.prototype.toString.call(Error) : [object Function]   
  14. Object.prototype.toString.call(EvalError) : [object Function]   
  15. Object.prototype.toString.call(/t/) : [object RegExp]   

 

ecma 262 spec

 

Js代码
  1. Object.prototype.toString.call(String.prototype) : [object String]   
  2. Object.prototype.toString.call(Number.prototype) : [object Number]   
  3. Object.prototype.toString.call(undefined) : global object implementation dependent   
  4. Object.prototype.toString.call(null) : global object implementation dependent   
  5. Object.prototype.toString.call(Boolean.prototype) : [object Boolean]   
  6. Object.prototype.toString.call(Function.prototype) : [object Function]   
  7. Object.prototype.toString.call(Array.prototype) : [object Array]   
  8. Object.prototype.toString.call(Date.prototype) : [object Date]   
  9. Object.prototype.toString.call(RegExp.prototype) : [object RegExp]   
  10. Object.prototype.toString.call(Object.prototype) : [object Object]   
  11. Object.prototype.toString.call(Error.prototype) : [object Error]   
  12. Object.prototype.toString.call(EvalError.prototype) : [object Error]   
  13. Object.prototype.toString.call(Error) : [object Function]   
  14. Object.prototype.toString.call(EvalError) : [object Function]   
  15. Object.prototype.toString.call(/t/) : [object Object]   

为什么要用Object.prototype.toString而不是Function.prototype.toString或者其它?这是和他们的toString解释方式有关系的。下面是ECMA中对Object.prototype.toString的解释:

Object.prototype.toString( )
When the toString method is called, the following steps are taken:
1. Get the [[Class]] property of this object.
2. Compute a string value by concatenating the three strings “[object “, Result (1), and “]”.
3. Return Result (2)

其过程简单说来就是:1、获取对象的类名(对象类型)。2、然后将[object、获取的类名、]组合并返回。

ECMA中对Array有如下说明:

The [[Class]] property of the newly constructed object is set to “Array”.

因此我们用如下代码来检测数组:

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


 

这种方式既解决了instanceof存在的跨页面问题,也解决了属性检测方式所存在的问题,实在是一种妙招,一个很好的解决方案。

除此之外,这种解决办法也可以应用于判断Date,Function等类型的对象

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值