js中arguments的作用

在javascript函数体内,标识符arguments具有特殊含义。它是调用对象的一个特殊属性,用来引用Arguments对象。 Arugments对象就像数组,注意这里只是像并不是哈。

javascript函数体内,arguments像数组(并不是真的数组,是一个Arguments对象, 再次强调)一样,有length属性,可以代表传给函数的参数的个数。

引用一个形式参数可以用参数名,也可以用arguments[]数组形式,其中arguments[0]表示第一个参数。

arguments.length属性:

js不会主动为你判断你到底给函数传了多少个参数,如果你多传了,多余的部分就没有被使用,如果你少传了,那么没传的参数值就是undefined

所以我们可以借助arguments的length属性来检测调用函数时是否使用了正确数目的实际参数,因为javascript是不会为你做这些 事的

function f(x,y,z)
{
  //首先检查传递的参数数量是否正确
  if(arguments.length!=3)
  {
      thrownew Error("function f called with "+ arguments.length+"arguments ,but it not 3 arguments.");
  }
  //下面运行真正的函数
}
arguments还为我们提供了这样一种可能,就是为一个函数传任意数目的实际参数:

比如说,我想判断你传给我的一些数字的大小,取出最大的那个,对,没错,你传多少参数都行,但是前提是你要传数字,因为我在函数内部懒得判断了。 呵。

function max()
{
  //根据我上一篇日志,这已经是JavaScript内最小的数字了
  var m = Number.NEGATIVE_INFINITY;
  for(var i =0; i < arguments.length; i++)
  {
      //只要有任何一个参数比m大,那么m就变成了这个参数的值
      if(arguments[i]> m)
           m = arguments[i];
  }
  return m;
}
怎么样?这个方法很巧妙吧?呵呵。

说明一下arguments与真正传的形式参数是一致的:

比如,你给函数传了一个叫param的参数,并且只有这一个参数,那么param与arguments[0]都是对这个参数值的引用,

改变其中一个值,即改变了二者所有的值

function change(param)
{
  //比如我传的param为simaopig,那么alert就是simaopig,
  //如果啥也没传就会alert undefined
  alert(param);
  //用arguments[0]改变了这个参数的值
   arguments[0]=‘xiaoxiaozi‘;
  //没错,这个值变成了xiaoxiaozi
  alert(param);
}
arguments的callee属性:

arguments的callee属性是用来引用当前正在执行的函数,这对未命名的函数调用自身非常有好处。

现在用arguments的这个callee同样可以简单的实现

//用函数直接量,采用arguments.callee属性实现递归函数
var result =function(x){
  if(x<=1)return1;
  return x*arguments.callee(x-1);
};
在最后提醒大家一点,既然这个arguments这么厉害,那么我们就不要为变量命名为arguments 了,事实上arguments是javascript的保留字之一.

  

时间: 2024-08-04 00:16:23

js中arguments的作用的相关文章

JS中冒号的作用

转载: JS中冒号的作用1.声明对象的成员2.switch语句分支3.三元表达式 1.声明对象的成员 var Book ={    Name: '法',    Price: 100,    Discount : function(rate)   {       this.Price *= rate;    }};alert(Book.Price);Book.Discount(0.8); // 8折alert(Book.Price); 2.switch语句分支 var a = 2;switch (

js中with的作用

js中with的作用当一个对象有多个需要操作的属性或方法时,可以使用如<体>试验<script type=“text/javascript”>var o=文件.创建元素(“DIV”):(o){风格.cursor=“指针”:style.zindex=“100”:innerhtml=“aaaaa”:}文件.身体.附录子项(o):</Script ><正文>上述代码相当于<体>试验<script type=“text/javascript”>

js 中arguments的应用

在js中每个函数类都有一个Arguments对象实例arguments,.首先他不是一个数组,可以说算一个伪数组,但是用数组的索引形式也能获取到他的值,如 let len = arguments.length;表示函数参数的个数 arguments[0]表示第一个参数 在函数中使用它的好处就是这个函数在多处调用且参数有不是必须传递的,这样可以利用arguments来处理,解决了不需要的参数也要传递的问题 在实际应用中分装的函数中使用了一下,有不对的和需要改进的地方,还请大家多多指教,一起学习 e

浅谈js中arguments对象

一.先来看看到底是个啥? arguments对象在JS中应该算数比较特殊的对象.不能显示的创建,只在当前函数调用的时候才可以使用,长得有点像数组,但绝对不是Array的实例. 几点说明: 1.1.arguments实际上是当前函数的一个内置属性,在当前函数内,函数名.arguments等价于arguments,在函数外单独使用arguments是没有意义的; 1.2.arguments对象的长度由实际参数个数决定.1.3.函数中的形参和实参是可以相互影响的. 可以看出,当传入的实参个数少于形参个

js中arguments的用法

本文导读:Javascript并没有重载函数的功能,但是Arguments对象能够模拟重载.Javascrip中国每个函数都会有一个Arguments对象实例arguments,它引用着函数的实参,可以用数组下标的方式"[]"引用arguments的元素.arguments.length为函数实参个数,arguments.callee引用函数自身. arguments特性 arguments对象不能显式创建,arguments对象只有函数开始时才可用.函数的 arguments 对象并

JS中arguments

对象数组:主要保存函数参数 属性:cellee,指向拥有arguments对象的函数. 返回正被执行的Function 对象,            也就是所指定的 Function 对象的正文.callee 属性是 arguments 对象的一个成员,仅当相关函数正在执行时才可用.         This:函数调用语句所在作用域.函数的调用者. { Argument的个数是由实参决定的,不是形参决定的 对于arguement和形参,实参值都存在的情况下,形参和arguement是同步的,否则

js中return的作用及用法

这里面的return含有一些细节知识: 例如:onClick='return add_onclick()'与 onClick='add_onclick()'的区别 JAVASCRIPT在事件中调用函数时用return返回值实际上是对window.event.returnvalue进行设置. 而该值决定了当前操作是否继续.当返回的是true时,将继续操作.当返回是false时,将中断操作. 而直接执行时(不用return).将不会对window.event.returnvalue进行设置所以会默认

js中arguments的应用

arguments数组的操作 arguments是一个类数组对象,这个数组里面保存的是传递给一个函数的参数 例子:求和 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xht

js中arguments,caller,callee,apply的用法小结

<!DOCTYPE HTML> <html> <head> <meta charset="UTF-8"> <style type="text/css"> *{padding: 0;margin: 0;} #img{position: absolute;} </style> </head> <body> <img id="img" src=&quo