一、caller
返回一个对函数的引用,该函数调用了当前函数。
functionName.caller
functionName 对象是所执行函数的名称。
说明
对于函数来说,caller 属性只有在函数执行时才有定义。 如果函数是由 Javascript 程序的顶层调用的,那么 caller 包含的就是 null 。
下面的例子说明了 caller 属性的用法:
function callerDemo() { if ( arguments.caller) { var a= callerDemo.caller.toString(); alert(a); } else { alert("this is a top function"); } } function handleCaller() { callerDemo(); } handleCaller(); function calleeDemo() { alert(arguments.callee); } calleeDemo();
二、callee
返回正被执行的 Function 对象,也就是所指定的 Function 对象的正文。
[function.]arguments.callee
可选项 function 参数是当前正在执行的 Function 对象的名称。
说明
callee 属性的初始值就是正被执行的 Function 对象。
callee 属性是 arguments 对象的一个成员,它表示对函数对象本身的引用,这有利于匿名函数的递归或者保证函数的封装性,例如下边示例的递归计算1到n的自然数之和。而该属性仅当相关函数正在执行时才可用。还有需要注意的是callee拥有length属性,这个属性有时候用于验证还是比较好的。arguments.length是实参长度,arguments.callee.length是形参长度,由此可以判断调用时形参长度是否和实参长度一致。
示例
//callee可以打印其本身 function calleeDemo() { alert(arguments.callee); } //用于验证参数 function calleeLengthDemo(arg1, arg2) { if (arguments.length==arguments.callee.length) { window.alert("验证形参和实参长度正确!"); return; } else { alert("实参长度:" +arguments.length); alert("形参长度: " +arguments.callee.length); } } //递归计算 var sum = function(n){ if (n < = 0) return 1; else return n +arguments.callee(n - 1) }
var sum = function(n){ if (1==n) return 1; else return n + sum (n-1);
调用时:alert(sum(100));
其中函数内部包含了对sum自身的引用,函数名仅仅是一个变量名,在函数内部调用sum即相当于调用
一个全局变量,不能很好的体现出是调用自身,这时使用callee会是一个比较好的方法。
本文向大家介绍javascript中caller和callee详解,包括了javascript中caller和callee详解的使用技巧和注意事项,需要的朋友参考一下 最近学习javascript,碰到caller和callee的问题,去网上百度了很多。搜到的内容大同小益,整理总结了一下与大家分享。 caller:返回一个对调用function函数的函数的引用(用法:function.caller
本文向大家介绍callee和caller的区别和作用是什么?相关面试题,主要包含被问及callee和caller的区别和作用是什么?时的应答技巧和注意事项,需要的朋友参考一下 arguments.callee 指的是当前函数 Function.caller 指的是调用当前函数的函数 举个例子: 控制台输出: [Function: a] [Function: b] [Function: a] nul
本文向大家介绍JS中attr和prop属性的区别以及优先选择示例介绍,包括了JS中attr和prop属性的区别以及优先选择示例介绍的使用技巧和注意事项,需要的朋友参考一下 相比attr,prop是1.6.1才新出来的,两者从中文意思理解,都是获取/设置属性的方法(attributes和properties)。只是,window或document中使用.attr()方法在jQuery1.6之前不能正
主要内容:1 ThreadPoolExecutor的概述,2 ThreadPoolExecutor的主要属性,2.1 ctl相关方法,2.2 线程池的状态,3 ThreadPoolExecutor的构造器,3.1. corePoolSize、workQueue,maximumPoolSize ,keepAliveTime,unit之间关系,3.2 ThreadFactory 线程工厂,3.3 workQueue任务队列,基于JDK1.8详细介绍了ThreadPoolExecutor线程池的基本属
本文向大家介绍js实例属性和原型属性示例详解,包括了js实例属性和原型属性示例详解的使用技巧和注意事项,需要的朋友参考一下 详情请仔细研读注释,这里就废话少说,直接上代码了。 小伙伴们是否看明白了,了解了实例属性和原型属性了吗?本文讲述的非常的详细,推荐给大家,希望对小伙伴们能有所帮助
本文向大家介绍js中的内部属性与delete操作符介绍,包括了js中的内部属性与delete操作符介绍的使用技巧和注意事项,需要的朋友参考一下 在讲解Configurable之前,我们首先来看一道面试题: 从上面的这道题可以看出两个的区别:在没有使用var声明变量时,使用delete关键词是可以进行删除的,再次获取时值就是undefined了;在使用var声明的变量,使用delete是不能删除的,