在判断函数类型时,我们通常使用typeof方法,一般情况下,它会得到我们所预想的效果。但是,有一些细节并不为我们所熟知。John Resig 在分析了这些细节之后,为我们提供了一个完美的解决方案,本文将作详细介绍: 一、传统方法不为人所知的细节 毫无疑问,在判断函数类型时,我们使用的是typeof方法,比如: function fn(){ 但是,该方法在一些浏览器中并不是像我们想像的那样工作。 1、Firefox2和Firefox3 在这两个浏览器中,用typeof检测HTML对象元素的类型,得到是一个不精确的“function”结果,而不是“object”,如HTMLDocument。如: alert(typeof HTMLDocument); 2、Firefox2 对于正则表达式,在该浏览器中返回的结果是“function”(在Firefox3中结果是“object”),如: var reg = /test/; 注:本人在safari中测试,其结果也是“function”。 3、IE6和IE7 在IE中对DOM元素使用typeof方法,得到的结果是“object”。如: alert(typeof document.getElementsByTagName("body")[0].getAttribute); 4、Safari 3 safari认为DOM元素的NodeList是一个函数,如: alert(typeof document.body.childNodes); 很明显,如果你要测试一个对象是否为函数,使用typeof方法并不能从真正意义上保证测试结果。那么,我们就需要一种在所有浏览器中都能保证测试 alert(typeof document.getElementsByTagName("body")[0].getAttribute.call) 显然,我们不能利用这两个方法。 二、完美解决方案及实现过程 John Resig为我们提供了一个完美的解决方案,这个复杂但很稳定的判断一个对象是否为函数的方法如下: function isFunction( fn ) { 这个函数首先保证测试的对象存在,并将其序列化成含有“function”的字符串,这个是我们检测的基础(fn.constructor != John Resig 原文:http://www.denisdeng.com/?p=426 |