一.定义参数
1.函数参数包括两种类型:形参和实参。形参就是函数声明的变量,它仅在函数内部可见,实参就是实际传递的参数值。
//【示例1】下面代码定义一个简单的函数。
function f(a,b){ // 定义函数结构,传递形参a和b
return a+b;
}
var x=1,y=2; // 定义参数变量
alert(f(x,y)); // 调用函数并传递实参
//【示例2】针对上面的函数,使用如下方法可以获取它的形参个数。
alert(f.length); // 返回2.获取函数的形参个数
//【示例3】如果函数实参数量少于形参数量,那么多出来的形参的值默认为undefined。
(function(a,b){ // 定义函数,包含两个形参
alert(typeof a); // 返回number
alert(typeof b); // 返回undefined
})(1); // 调用函数,传递一个实参
//【示例4】如果函数实参数量多于形参数量,那么多出来的实参就不能够通过形参标识符访问,函数会忽略掉多余的实参。在下面这个示例中,实参3和4就被忽略掉了。
(function(a,b){ // 定义函数,包含两个形参
alert(a); // 返回1
alert(b); // 返回2
})(1,2,3,4); // 调用函数,传递四个实参
//【示例5】形参与函数体内使用var语句声明的变量都属于局部变量,仅在函数体内可见。当私有变量与形参发生冲突时,则私有变量拥有较大的优先权。
function f(a){ //定义函数结构,传递形参a
var a = 0; //声明私有变量a,初始值为0
return a;
}
alert(f(5)); // 调用函数,传递给参数值为5,则返回值为0
2.使用arguments对象
arguments对象表示参数集合,它是一个伪类数组,拥有与数组相似的结构,可以通过数组下标的形式访问函数实参值,但是没有基础Array的原型方法。
//【示例1】在下面示例中,函数没有定义形参,但是在函数体内通过arguments对象可以获取传递给该函数的每个实参值。
function f(){ // 定义没有形参的函数
for(var i = 0; i < arguments.length; i ++ ){
// 循环读取函数的arguments对象
alert(arguments[i]); // 显示指定下标的实参的值
}
}
f(3, 3, 6); // 逐个显示每个传递的实参
///【示例2】arguments对象仅能够在函数体内使用,作为函数的属性而存在。用户可以通过点运算符访问arguments对象。由于arguments对象在函数体内是可见的,也直接引用arguments对象。
function f(){ // 定义没有形参的函数
for(var i = 0; i < f.arguments.length; i ++ ){
// 循环读取函数的arguments对象
alert(arguments[i]); // 显示指定下标的实参的值
}
}
f(3, 3, 6); // 逐个显示每个传递的实参
///【示例3】使用arguments对象可以随时编辑实参值。在下面示例中使用for循环遍历arguments对象,然后把循环变量的值传递给实参,以便动态改变实参值。
function f(){
for(var i = 0; i < arguments.length; i ++ ){
// 遍历arguments对象元素
arguments[i] =i; // 修改每个实参的值
alert(arguments[i]); // 提示修改的实参值
}
}
f(3, 3, 6); // 返回提示1、2、3,而不是3、3、6
//【示例4】通过修改arguments对象的length属性值,也可以达到改变函数实参个数的目的。当length属性值增大时,则增加的实参值为undefined,如果length属性值减小,则会丢弃arguments数据集合后面对应个数的元素。
function f(){
arguments.length = 2 ; // 修改arguments对象的length属性值
for(var i = 0; i < arguments.length; i ++ ){
alert(arguments[i]);
}
}
f(3, 3, 6); // 返回提示3、3