Javascript 判断函数类型完美解决方案


Posted in Javascript onSeptember 02, 2009

但是,有一些细节并不为我们所熟知。John Resig 在分析了这些细节之后,为我们提供了一个完美的解决方案,本文将作详细介绍:

一、传统方法不为人所知的细节
毫无疑问,在判断函数类型时,我们使用的是typeof方法,比如:

function fn(){ 
//content 
} 
alert(typeof fn)//结果是"function"。

但是,该方法在一些浏览器中并不是像我们想像的那样工作。

1、Firefox2和Firefox3
在这两个浏览器中,用typeof检测HTML对象元素的类型,得到是一个不精确的“function”结果,而不是“object”,如HTMLDocument。如:

alert(typeof HTMLDocument); 
//在Firefox2中结果是"function"; 
//在Firefox3中结果是"object";

2、Firefox2
对于正则表达式,在该浏览器中返回的结果是“function”(在Firefox3中结果是“object”),如:
var reg = /test/; 
alert(typeof reg); 
//在Firefox2中结果是"function"; 
//在Firefox3中结果是"object";

注:本人在safari中测试,其结果也是“function”。
3、IE6和IE7
在IE中对DOM元素使用typeof方法,得到的结果是“object”。如:
alert(typeof document.getElementsByTagName("body")[0].getAttribute); 
//结果是"object"

4、Safari 3
safari认为DOM元素的NodeList是一个函数,如:
alert(typeof document.body.childNodes); 
//结果是"function"

很明显,如果你要测试一个对象是否为函数,使用typeof方法并不能从真正意义上保证测试结果。那么,我们就需要一种在所有浏览器中都能保证测试结果的解决方案。我们知道function本身有apply()和call()两种方法,但这两个方法在IE中存在问题的函数中并不存在,试试下面的测试:
alert(typeof document.getElementsByTagName("body")[0].getAttribute.call) 
//在IE中结果是"undefined"

显然,我们不能利用这两个方法。

二、完美解决方案及实现过程
John Resig为我们提供了一个完美的解决方案,这个复杂但很稳定的判断一个对象是否为函数的方法如下:

function isFunction( fn ) { 
return !!fn && !fn.nodeName && fn.constructor != String && 
fn.constructor != RegExp && fn.constructor != Array && 
/function/i.test( fn + "" ); 
}

这个函数首先保证测试的对象存在,并将其序列化成含有“function”的字符串,这个是我们检测的基础(fn.constructor != String,fn.constructor != Array, and fn.constructor != RegExp)。另外,我们需要保证声明的函数不是一个DOM节点(fn.nodeName)。然后,我们就可以作toString测试。如果我们将一个函数转换成字符串,在一个浏览器中(fn+"")给我们的结果就像这样“function name(){...}”。现在,判断它是否为函数就很简单,仅仅只需要判断字符串中是否包含单词“function”。这很神奇,对于任何有问题的函数,在所有浏览器中都能得到我们所需要的结果。这个函数较之于传统的方法,运行速度有些不尽人意,作者建议我们保守使用。

John Resig 是jQuery库的开发者,相信使用该库的朋友们对该库简洁的语法和优秀的性能并不陌生。作者除追求代码简洁和性能高效之外,其尽善尽美的精神也让人叹服。如果你是一个完美主义者,相信此文对你很有帮助。

Javascript 相关文章推荐
javascript数字数组去重复项的实现代码
Dec 30 Javascript
iframe 异步加载技术及性能分析
Jul 19 Javascript
基于socket.io和node.js搭建即时通信系统
Jul 30 Javascript
了不起的node.js读书笔记之node的学习总结
Dec 22 Javascript
JS实现左右拖动改变内容显示区域大小的方法
Oct 13 Javascript
jQuery ajax应用总结
Jun 02 Javascript
JS实现定时任务每隔N秒请求后台setInterval定时和ajax请求问题
Oct 15 Javascript
parabola.js抛物线与加入购物车效果的示例代码
Oct 25 Javascript
JavaScript实现多叉树的递归遍历和非递归遍历算法操作示例
Feb 08 Javascript
详解小程序开发经验:多页面数据同步
May 18 Javascript
JS自定义对象创建与简单使用方法示例
Jan 15 Javascript
uni-app微信小程序登录授权的实现
May 22 Javascript
javascript 控制 html元素 显示/隐藏实现代码
Sep 01 #Javascript
jsTree树控件(基于jQuery, 超强悍)[推荐]
Sep 01 #Javascript
JavaScript 继承详解 第一篇
Aug 30 #Javascript
JavaScript 应用技巧集合[推荐]
Aug 30 #Javascript
用cssText批量修改样式
Aug 29 #Javascript
javascript appendChild,innerHTML,join性能比较代码
Aug 29 #Javascript
IE 条件注释详解总结(附实例代码)
Aug 29 #Javascript
You might like
php采集速度探究总结(原创)
2008/04/18 PHP
使用php get_headers 判断URL是否有效的解决办法
2013/04/27 PHP
PHP的PSR规范中文版
2013/09/28 PHP
PDO防注入原理分析以及注意事项
2015/02/25 PHP
在Win2003(64位)中配置IIS6+PHP5.2.17+MySQL5.5的运行环境
2016/04/04 PHP
YII2自动登录Cookie总是失效的解决方法
2017/06/28 PHP
PHP根据key删除数组中指定的元素
2019/02/28 PHP
深入解析PHP底层机制及相关原理
2020/12/11 PHP
javascript使用中为什么10..toString()正常而10.toString()出错呢
2013/01/11 Javascript
javascript 上下banner替换具体实现
2013/11/14 Javascript
jQuery+css实现百度百科的页面导航效果
2014/12/16 Javascript
JS继承用法实例分析
2015/02/05 Javascript
jQuery Ajax中的事件详细介绍
2015/04/16 Javascript
jQuery插件制作的实例教程
2016/05/16 Javascript
js实现做通讯录的索引滑动显示效果和滑动显示锚点效果
2017/02/18 Javascript
基于javascript中的typeof和类型判断(详解)
2017/10/27 Javascript
vue watch普通监听和深度监听实例详解(数组和对象)
2018/08/16 Javascript
使用React-Router实现前端路由鉴权的示例代码
2020/07/26 Javascript
Python实用日期时间处理方法汇总
2015/05/09 Python
详解Python中的__getitem__方法与slice对象的切片操作
2016/06/27 Python
简单谈谈Python中的json与pickle
2017/07/19 Python
python数据抓取分析的示例代码(python + mongodb)
2017/12/25 Python
Django 简单实现分页与搜索功能的示例代码
2019/11/07 Python
在Python中使用MongoEngine操作数据库教程实例
2019/12/03 Python
python实现引用其他路径包里面的模块
2020/03/09 Python
Smashbox英国官网:美国知名彩妆品牌
2017/11/13 全球购物
波兰运动鞋网上商店:e-Sporting
2018/02/16 全球购物
德国药房apodiscounter中文官网:德国排名前三的网上药店
2019/06/03 全球购物
《翻越远方的大山》教学反思
2014/04/13 职场文书
员工三分钟演讲稿
2014/08/19 职场文书
保险公司演讲稿
2014/09/02 职场文书
毕业证代领委托书
2014/09/26 职场文书
民间借贷协议书范本
2014/10/01 职场文书
证婚人婚礼致辞
2015/07/28 职场文书
奖学金申请书(范文)
2019/08/14 职场文书
分布式架构Redis中有哪些数据结构及底层实现原理
2022/03/13 Redis