首页 > web前端 > js教程 > 正文

JavaScript 之arguments、caller 和 callee 介绍

高洛峰
发布: 2016-11-26 16:15:36
原创
1500人浏览过

1.前言

arguments, caller ,   callee 是什么?

javascript 中有什么样的作用?本篇会对于此做一些基本介绍。

 

2. arguments

立即学习Java免费学习笔记(深入)”;

arguments:  在函数调用时, 会自动在该函数内部生成一个名为 arguments的隐藏对象。 该对象类似于数组, 但又不是数组。可以使用[]操作符获取函数调用时传递的实参。

[html]  

<!--by oscar999 2013-1-16-->    

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  

<html>  

<head>  

<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">  

<title>Arguments Test</title>  

</head>  

<body>  

<script>  

function testArg()  

{  

    alert("real parameter count: "+arguments.length);  

    for(var i = 0; i < arguments.length; i++)  

    {  

        alert(arguments[i]);  

    }  

}  

  

  

testArg(11);  //count: 1      

testArg('hello','world');  // count: 2    

</script>  

</body>  

</html>  

看上去很简单。 需要注意的是 argument 保存的实参的信息。

 

上面有说,   arguments 不是一个数组,何以见得? 执行以下部分就可以知道了

[javascript]  

(function () {  

    alert(arguments instanceof Array); // false  

    alert(typeof(arguments)); // object  

})();  

对于以上立即执行函数写法不清楚的话, 可以参考

Flawless AI
Flawless AI

好莱坞2.0,电影制作领域的生成式AI工具

Flawless AI 32
查看详情 Flawless AI

http://blog.csdn.net/oscar999/article/details/8507919

 

只有函数被调用时,arguments对象才会创建,未调用时其值为null:

[javascript]  

alert(new Function().arguments);//return null  

 

arguments 的完整语法如下:

[function.]arguments[n]

参数function :选项。当前正在执行的 Function 对象的名字。 n :选项。要传递给 Function 对象的从0开始的参数值索引。 

 

3. caller

在一个函数调用另一个函数时,被调用函数会自动生成一个caller属性,指向调用它的函数对象。如果该函数当前未被调用,或并非被其他函数调用,则caller为null。

 

[javascript]  

<script>  

function testCaller() {  

    var caller = testCaller.caller;  

    alert(caller);  

}  

  

function aCaller() {  

    testCaller();  

}  

  

aCaller();  

 

4. callee

当函数被调用时,它的arguments.callee对象就会指向自身,也就是一个对自己的引用。

由于arguments在函数被调用时才有效,因此arguments.callee在函数未调用时是不存在的(即null.callee),且解引用它会产生异常。

[javascript]  

<script>  

function aCallee(arg) {  

  alert(arguments.callee);  

}  

  

function aCaller(arg1, arg2) {aCallee();}  

  

aCaller();  

</script>  

相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号