1、在JavaScript中,arguments对象是比较特别的一个对象,实际上是当前函数的一个内置属性。arguments非常类似Array,但实际上又不是一个Array实例。可以通过如下代码得以证实(当然,实际上,在函数funcArg中,调用arguments是不必要写成funcArg.arguments,直接写arguments即可)。

1 Array.prototype.testArg = "test";
2 function funcArg() {
3     alert(funcArg.arguments.testArg);
4     alert(funcArg.arguments[0]);
5 }
6
7 alert(new Array().testArg); // result: "test"
8 funcArg(10);                // result: "undefined"  "10"

2、arguments对象的长度是由实参个数而不是形参个数决定的。形参是函数内部重新开辟内存空间存储的变量,但是其与arguments对象内存空间并不重叠。对于arguments和值都存在的情况下,两者值是同步的,但是针对其中一个无值的情况下,对于此无值的情形值不会得以同步。如下代码可以得以验证。

 1 function f(a, b, c){2     alert(arguments.length);   // result: "2"3     a = 100;4     alert(arguments[0]);       // result: "100"5     arguments[0] = "qqyumidi";6     alert(a);                  // result: "qqyumidi"7     alert(c);                  // result: "undefined"8     c = 2012;9     alert(arguments[2]);       // result: "undefined"
10 }
11
12 f(1, 2);

3、由JavaScript中函数的声明和调用特性,可以看出JavaScript中函数是不能重载的。

根据其他语言中重载的依据:"函数返回值不同或形参个数不同",我们可以得出上述结论:

第一:Javascript函数的声明是没有返回值类型这一说法的;

第二:JavaScript中形参的个数严格意义上来讲只是为了方便在函数中的变量操作,实际上实参已经存储在arguments对象中了。

另外,从JavaScript函数本身深入理解为什么JavaScript中函数是不能重载的:在JavaScript中,函数其实也是对象,函数名是关于函数的引用,或者说函数名本身就是变量。对于如下所示的函数声明与函数表达式,其实含义上是一样的(在不考虑函数声明与函数表达式区别的前提下),非常有利于我们理解JavaScript中函数是不能重载的这一特性。

 1 function f(a){2     return a + 10;3 }4 5 function f(a){6     return a - 10;7 }8 9 // 在不考虑函数声明与函数表达式区别的前提下,其等价于如下
10
11 var f = function(a){
12     return a + 10;
13 }
14
15 var f = function(a){
16     return a - 10;
17 }

4、arguments对象中有一个非常有用的属性:callee。arguments.callee返回此arguments对象所在的当前函数引用。在使用函数递归调用时推荐使用arguments.callee代替函数名本身。

如下:

1 function count(a){
2     if(a==1){
3         return 1;
4     }
5     return a + arguments.callee(--a);
6 }
7
8 var mm = count(10);
9 alert(mm);

--------------------------------------------------------------------------------- 

转载自http://www.cnblogs.com/lwbqqyumidi/

转载于:https://www.cnblogs.com/ztoz/p/5510293.html

JavaScript arguments对象相关推荐

  1. JavaScript学习系列3 -- JavaScript arguments对象学习

    在实际项目开发中,目前还是很少使用到JavaScript 中的arguments对象,那么它到底是干什么用的呢 arguments是JavaScript中的一个类数组对象,它代表传给一个正在执行的函数 ...

  2. javascript arguments对象研究--针对jquery源码研究再研究

    外部插件: $.fn.tinytip = function(text, customOptions) {     debugger;         if (text && typeo ...

  3. JavaScript教程——函数(arguments 对象)

    arguments 对象 定义 由于 JavaScript 允许函数有不定数目的参数,所以需要一种机制,可以在函数体内部读取所有参数.这就是arguments对象的由来. arguments对象包含了 ...

  4. JavaScript中的arguments对象

    JavaScript中的arguments对象 arguments 是一个类似数组的对象, 对应于传递给函数的参数. 语法 arguments 描述 arguments对象是所有函数中可用的局部变量. ...

  5. JavaScript学习(五十七)— arguments对象

    JavaScript学习(五十七)- arguments对象 arguments对象 该对象是函数内部的一个属性,这个属性本身也是一个对象 这个对象是用来管理函数被调用时传过来的实参的 argumen ...

  6. 你知道 JavaScript 中的 Arguments 对象都有哪些用途吗?

    JavaScript 中 Arguments 对象的用途总结. 前言 相信我们很多人在代码开发的过程中都使用到过一个特殊的对象 -- Arguments 对象. 在实际开发中,Arguments 对象 ...

  7. Effective JavaScript Item 23 永远不要修改arguments对象

    本系列作为Effective JavaScript的读书笔记. arguments对象只是一个类似数组的对象,但是它并没有数组对象提供的方法,比如shift,push等.因此调用诸如:argument ...

  8. javascript arguments 特殊 对象

    在函数代码中,使用特殊对象arguments,开发者无需明确指出参数名,就能访问它们, arguments对象:在函数执行时函数内部就会有arguments对象,它包含了所有的参数,arguments ...

  9. [Effective JavaScript 笔记]第23条:永远不要修改arguments对象

    arguments对象并不是标准的Array类型的实例.arguments对象不能直接调用Array方法. arguments对象的救星call方法 使得arguments可以品尝到数组方法的美味,知 ...

最新文章

  1. 无线传输系统功率LCC功率补偿系统设计
  2. 二丶Linux安装xdd-plus教程及必备依赖的安装+青龙对接xdd
  3. React技术栈——webpack
  4. 大概率有料的地方,大概率没有料的地方
  5. @RequestMapping报404错误问题解决
  6. How to use the SQLIOSim utility to simulate SQL Server activity on a disk subsystem
  7. c语言中eles后面分号的作用,C语言 if else 语句详细讲解
  8. 再议 封装、继承、多态
  9. 计算机投影仪的作用是什么,解开无屏电脑投影仪的神秘面纱,看看可以用它来做什么...
  10. ae编程语言as_18种常用AE表达式解析
  11. Kudu之Tablet的发现过程
  12. html5电子时钟怎么往上移动,html5旋转 怎样用HTML5制作旋转时钟
  13. python 提取字幕_使用Python从zimuku下载字幕
  14. C语言求x的y次方,fun函数实现x的y次方的计算,main函数中调用fun函数
  15. linux 原子变量
  16. 如何查看自己的ubuntu系统版本
  17. 我的世界java版如何装mod_我的世界MOD怎么安装 MOD安装简易教程
  18. 【JavaSE 第八天】
  19. 基于Vue的医院内部管理系统(医生、患者、挂号、药房)文档+答辩PPt+项目源码+演示视频
  20. Proxy Switchysharp配置

热门文章

  1. 《introduction to information retrieval》信息检索学习笔记3 词典和容错式检索
  2. 基于深度学习的口罩识别与检测PyTorch实现
  3. 计算机基础2多媒体,《计算机基础》第2章-多媒体技术.pptx
  4. java获取达梦数据库_Java连接达梦数据库驱动dm_jdbc
  5. linux sh for ls,Linux shell for while 循环
  6. android mp4宽高,Android:MediaPlayer视频宽高比问题
  7. cap mysql_.NetCore关于Cap(RabbitMQ)结合MySql使用出现MySql相关类冲突问题解决办法
  8. Linux软件包增量升级,Linux增量更新jar包内容
  9. Image Processing图像处理(对比俩张图像的差异并且在图上标注出来)
  10. 【机器视觉案例】(9) AI视觉,手势控制电脑键盘,附python完整代码