js函数有两个隐式参数 arguments 和 this,arguments是一个类数组结构,它保存了调用时传递给函数的所有实参;this是函数执行时的上下文对象
arguments关键字体现重载
//arguments关键字
function f1(){
//console.log('个人信息:'+"名字:"++";年龄:"++";地址:"+);
//console.log(arguments);
//console.log(arguments.length); //获得传递参数的个数
var len = arguments.length;
//以下代码是利用arguments体会方法"重载"效果。
//重载:在java里边,一个类里边有许多方法,这些方法的名字一致,但是参数不一样(类型或个数)
if(len==0){
console.log('个人信息');
}else if (len==1){
console.log('个人信息-名字:'+arguments[0]);
}else if (len==2){
console.log('个人信息-名字:'+arguments[0]+";年龄:"+arguments[1]);
}else if (len==3){
console.log('个人信息-名字:'+arguments[0]+";年龄:"+arguments[1]+";地址:"+arguments[2]);
}
}
f1();
f1('tom');
f1('tom','20');
f1('linken','45','usa');
在js中一切都是对象,连函数也是对象,函数名其实是引用函数定义对象的变量。
1、什么是arguments?
这个函数体内的arguments非常特殊,实际上是所在函数的一个内置类数组对象,可以用数组的[i]和.length。
2、有什么作用?
js语法不支持重载!但可用arguments对象模拟重载效果。
arguments对象:函数对象内,自动创建的专门接收所有参数值得类数组对象。
arguments[i]: 获得传入的下标为i的参数值
arguments.length: 获得传入的参数个数!
重载的定义是指函数的方法名相同,但参数不同。比如我写两个关于js的同名函数:
输出结果为NaN 9,这就说明后面的函数把前一个同名函数覆盖掉了,从而可以得出js函数不存在重载,永远调用最后一个方法。
虽说JS函数不存在重载,但是我们可以实现js里面的模拟重载,如文章开头所示。要想实现js模拟重载必先回用到 arguments.用来存放js参数。
JavaScript里面的一个arguments对象。首先,ECMAScript函数的参数与其他语言的函数参数有一点不同。ECMAScript函数不介意传进来的参数个数和类型。
也就是说,在你定义了函数只接受两个参数之后,你仍然可以在调用的时候传递零或多个参数。这并不会报错。
原因就在于arguments对象。ECMAScript中,函数的参数始终是存放在一个数组中,而通过arguments对象,就可以访问到这个数组。
所以,只需要使用length属性就可以确定调用函数时传递了多少个参数。
对于arguments对象需要注意有以下几点:
1、arguments对象仅在函数内部有效,在函数外部调用arguments对象会出现一个错误
2、arguments的typeof返回的是‘object’
怎么变为数组?
循环遍历逐一填入新数组:
var args=[];
for(var i=1;i<arguments.length;i++){
args.push(arguments[i]);