欢迎您访问我爱IT技术网,今天小编为你分享的javascript教程:【javascript中callee与caller的区别分析】,下面是详细的讲解!
javascript中callee与caller的区别分析
callee
callee是对象的一个属性,该属性是一个指针,指向参数arguments对象的函数
首先我们来写个阶成函数:
function chen(x){
if (x<=1) {
return 1;
} else{
return x*chen(x-1);
};
};
从这个函数中可以看出来,用到了递归函数,要是改变了函数名,里面的函数名也要随着改变,这样很不方便所以我们用callee来试试
function chen(x){
if (x<=1) {return 1;
}else{
return x*arguments.callee(x-1);
};
};
我们来分析一下为什么这样写:根据callee的定义,可以看出来callee是arguments对象的一个属性,指向arguments对象的函数,这个函数就是chen(chen=arguments.callee),这样解释应该可以理解了吧。
caller
caller是函数对象的一个属性,该属性保存着调用当前函数的函数的引用(指向当前函数的直接父函数)
先来个例子吧
function a(){
b();
};
function b(){
alert(b.caller);
};
a(); //结果就是弹出函数a和内容
我们来解释一下吧,首先函数b的属性caller调用当前函数b的函数引用a(就是指向当前函数b的父函数a),所以结果就是弹出 function a(){ b();};
那么了解了caller和callee,那么可以不可以将二者结合在一起来使用呢
function b(){
alert(b.caller);
};
从这个代码可以看出b函数中调用了b函数名,这样当函数名改变时就很不方便,我们需要替换里面的那个b
前面我们知道用什么方法可以指向当前对象,下面我们就来修改一下:
(function a(){
b();
})();
function b(){
alert(arguments.callee.caller);
};
从代码中可以看出我们用arguments.callee代替了b函数,所以解决了一下麻烦。。。。。
以上所述就是本文的全部内容了,希望大家能够喜欢。
关于javascript中callee与caller的区别分析的用户互动如下:
相关问题:如何理解JavaScript中的caller,callee,call,app...
答:在提到上述的概念之前,首先想说说javascript中函数的隐含参数:arguments Arguments —— 该对象代表正在执行的函数和调用它的函数的参数。 [function.]arguments[n] 参数 function :选项。当前正在执行的 Function 对象的名字。 n :选项。要传... >>详细
相关问题:caller和callee的区别介绍及演示结果
答:因为代码较多 请自行去原帖子查看 http://www.jb51.net/article/34653.htm ---------------------------------------------------------- 您好,答题不易 如有帮助请采纳,谢谢 >>详细
相关问题:caller和callee的区别介绍及演示结果
答:caller caller返回一个函数的引用,这个函数调用了当前的函数。 使用这个属性要注意: 1 这个属性只有当函数在执行时才有用 2 如果在javascript程序中,函数是由顶层调用的,则返回null functionName.caller: functionName是当前正在执行的函数。... >>详细
- 【firefox】firefox浏览器不支持innerText的解决
- 【Extjs】Extjs学习过程中新手容易碰到的低级错误
- 【clearInterval】js clearInterval()方法的定义
- 【dom】javascript dom追加内容实现示例-追加内容
- 【checkbox】让checkbox不选中即将选中的checkbox
- 【Array】js中更短的 Array 类型转换-类型转换
- 【append】append和appendTo的区别以及appendChil
- 【ExtJs】ExtJs 表单提交登陆实现代码-表单提交-
- 【ajax清除浏览器缓存】Ajax清除浏览器js、css、
- 【AJAX】AJAX异步从优酷专辑中采集所有视频及信息
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
