typeof的一些兼容性问题

时间:2022-05-04
本文章向大家介绍typeof的一些兼容性问题,主要内容包括其使用实例、应用技巧、基本知识点总结和需要注意事项,具有一定的参考价值,需要的朋友可以参考一下。

typeof存在一些兼容性的问题,在IE6,7,8中的DOM和BOM元素及其对象上的方法的判定会出现误差,在safari上对NodeList实例

的判定,对ExpReg实例的判断(早期的chrome,safari会对ExpReg实例认定为‘function’)。

分析:

  之所以会在IE6,7,8对DOM和BOM元素及其方法判定错误,主要是因为在这3个版本的IE中,js引擎JScript并没有集成到IE浏览器内核

  中,通过COM组件链接JScript和IE内核,浏览器实现的BOM对象或者DOM对象及其方法必须通过COM组件转换到JScript上进行操作,

  转换过后的Function类型会变成Object类型。故在IE6,7,8中 typeof document.write === 'object'。

  而在IE9之后,js引擎内置于核心之中,也就不需要转换数据了,此后的BOM或者DOM对象的方法的类型判定是正确的。

  在Safari上,通过测试NodeList实例发现,实例的construct属性并不是函数,而是一个对象NodeListConstructor,typeof nodelist === 'function',

  在其他的浏览器上,Nodelist接口继承自HTMLCollection。

  综上,实现真正兼容性的typeof:

function _typeof(o){
      return typeof o === 'undefined'?
      undefined : typeof o === 'object' ?
      (/function/i.test(o + "") ?
      'function' : 'object')
      : (o.constructor == RegExp || (o.constructor !== Function)) ?
      'object' : typeof o

}