网站大量收购独家精品文档,联系QQ:2885784924

JavaScript arguments callee.doc

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
JavaScript arguments callee

caller : functionName.caller 返回调用者。 看看下面的函数,大家可以复制到VS中执行下 代码 function caller() { if (caller.caller) { alert(caller.caller.toString()); } else { alert(函数直接执行); } } function handleCaller() { caller(); } handleCaller(); caller(); 大家会发现第一个alert会弹出调用caller函数的调用者handleCaller,而第二个alert由于没有在其他函数体内调用,所以caller为null,就执行了 alert(函数直接执行); callee: 返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文. callee是arguments 的一个属性成员,它表示对函数对象本身的引用,这有利于匿名 函数的递归或者保证函数的封装性。 下面一段代码先说明callee的用法,实例代码摘自网上 代码 function calleeLengthDemo(arg1, arg2) { alert(arguments.callee.toString()); if (arguments.length == arguments.callee.length) { window.alert(验证形参和实参长度正确!); return; } else { alert(实参长度: + arguments.length); alert(形参长度: + arguments.callee.length); } } calleeLengthDemo(1); 第一个消息框弹出calleeLengthDemo函数本身,这说明callee就是函数本身对象的引用。callee还有个非常有用的应用就是用来判断实际参数跟行参是否一致。上面的代码第一个消息框会弹出实际参数的长度为1,形式参数也就是函数本身的参数长度为2. 应用场景: callee的应用场景一般用于匿名函数 大家看下下面一段代码 摘自网络 var fn=function(n){ if(n0) return n+fn(n-1); return 0; } alert(fn(10)) 函数内部包含了对自身的引用,函数名仅仅是一个变量名,在函数内部调用即相当于调用 一个全局变量,不能很好的体现出是调用自身,这时使用callee会是一个比较好的方法 var fn=(function(n){ if(n0) return n+arguments.callee(n-1); return 0; })(10); alert(fn) 这样就让代码更加简练。又防止了全局变量的污染。 caller的应用场景 主要用于察看函数本身被哪个函数调用。 在IE中,可以通过event或window.event获得全局event;而在其他浏览器中,则通过 arguments[arguments.length-1]可获得event实例。但是如果是嵌套调用,如:用户触发事件调用functionA,而 functionA又调用functionB,再由functionB调用functionC,此时如果functionB或functionC中需要获 得event实例,IE仍可通过event或window.event获得,而其他浏览器通过arguments[arguments.length- 1]就无法获得了,通常习惯的做法是把event作为参数传递到functionB及functionC中?. !DOCTYPE html PUBLIC -//W3C//DTD XHTML 1.0 Transitional//EN /TR/xhtml1/DTD/xhtml1-transitional.dtd html

文档评论(0)

cj80011 + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档