【javascript学习指南】Javascript中arguments实参、形参教程

更新时间:2019-11-24    来源:php函数    手机版     字体:

【www.bbyears.com--php函数】

在函数默认就有个arguments:他代表这个函数在执行的时候传进来的参数

arguments :实参,实际参数

arguments : 可变参(不定参) 指的是参数的个数是不固定的。
虽然不需要通过形参来传递值,但是如果修改了形参的值,arguments中相应位置上的值也会被修改。

代码片段

function count(a,b,c,d){ 
     
    //alert(c); 
     
    return a+b+c+d; 

alert(count(1,2,4,5)); //12 
alert(count(1,2,3,4)); //10 

代码片段

function count(a){ //形参:形式上参数 
     
     
    //arguments : 里面存的是所有实际传进来的参数的集合。 
     
    //return arguments.length; 
     
    //return arguments[1]; 
     
    a = 10; 
     
    var results = 0; 
     
    for(var i=0; i      
        results += arguments[i]; 
         
        //results = results + arguments[i]; 
         
    } 
     
    //0 + 1 + 4 + 3 + 10 + 20 
     
    return results; 

 
alert(count(1,4,3,10,20));  //实参  47 
 
alert(count(1,2)); // 12 
 
alert(count(1,4,3)); //6  0+1+4+3 
 
alert(count(1,2,3,4)); //10 0+1+2+3+4 

下面的示例演示了 JavaScript中arguments对象的用法。

function ArgTest(a, b){
   var i, s = "The ArgTest function expected ";
   var numargs = arguments.length;     // 获取被传递参数的数值。
   var expargs = ArgTest.length;       // 获取期望参数的数值。
   if (expargs < 2)
      s += expargs + " argument. ";
   else
      s += expargs + " arguments. ";
   if (numargs < 2)
      s += numargs + " was passed.";
   else
      s += numargs + " were passed.";
   s += "\n\n"
   for (i =0 ; i < numargs; i++){      // 获取参数内容。
   s += "  Arg " + i + " = " + arguments[i] + "\n";
   }
   return(s);                          // 返回参数列表。
}

形参是定义方法的时候,该方法所携带的参数,不如说现在有一个方法
public void printInfo(String info){
System.out.println(info);
}
此处info就是一个形参,它是String类型的。
实参是你在调用方法的时候,给这个方法传递的参数值,比如说有这么一个语句:
**.printInfo("hello");(此处**表示printInfo方法所在类的一个对象),这里的"hello"就是一个实参,实现方法调用的时候,系统会吧实参"hello"的值赋予形参info变量,即info就指向了"hello",调用这个方法后,就会在屏幕上打印输出hello

将函数参数arguments转为数组

1. arguments为什么不是数组?如何证明?

arguments 是没有数组的slice等方法的,所以不是Array类型的。

验证:

function testargs(){   
var arr=[1,2,3];    
console.log(typeof arguments.slice);    
console.log(typeof arr.slice); }
testargs();

输出:

undefined function

当然,还可以通过其他方式来证明,比如说看constructor等等。

2. 如何转为数组?

使用Array的slice方法,如下:

function arg2arr()
{    
var arr = Array.prototype.slice.call(arguments);    
console.log(arr);
}
arg2arr(1,2,3);

输出:[1,2,3]

还可以写成这样:

Array.prototype.slice.call(arguments, 0)

3. 如何使用原生JS实现自己的slice方法

 

Array.prototype.slice = function(start,end){     
 var result = new Array();     
 start = start || 0;      
end = end || this.length; //this指向调用的对象,当用了call后,能够改变this的指向,也就是指向传进来的对象,这是关键

for(var i = start; i < end; i++){  result.push(this[i]);  }  return result;  }

4. JS中有没有toArray方法?如果没有,如何自己实现一个?

var toArray = function(s){
try{  
return Array.prototype.slice.call(s);
} catch(e){ 
var arr = [];
for(var i = 0,len = s.length; i < len; i++){
 //arr.push(s[i]);
arr[i] = s[i];  //据说这样比push快
}
return arr;
}
}

本文来源:http://www.bbyears.com/jiaocheng/80939.html