形参,是在定义函数时使用的参数,目的是用来接收调用该函数时传进来的实际参数。
实参:是在调用时传递给函数的参数
例如
function myfun(a,b,c){
...
}
myfun(1,2,3);
这里a,b,c就是形参。1,2,3为实参。
形参和实参是不同的变量,他们在内存中处于不同的位置,形参在函数运行结束时将被释放。
主要有两点需要注意的
1 . 如果实参是引用类型(object,array等),那么对相对的形参进行更改,是否会影响到实参的值
var obj = {
name:'obj',
age:12
}
function myfunc(objtemp){
objtemp.name='func';
alert(objtemp.age); //12
}
myfunc(obj);
alert(obj.name); //func
那么最后一句:alert(obj.name);会输出什么呢,答案是func。
函数参数传递包含两种方式:值传递和引用传递。
值传递:形参是实参值的一个副本,对形参的改变不会影响实参
引用传递:形参实际上是对实参引用变量的复制,导致这实参、形参都指向同一个对象实体。形参改变会同时改变实参的值。
可以这样理解:myfunc(obj);可以看作是
objtemp = obj;
objtemp.name = 'func';
alert(objtemp.age);
举例说明:
var arr= ['obj1','obj2','obj3']
function myfunc(arrtemp){
arrtemp[1] = 'myfunc';
alert(arrtemp);
}
myfunc(arr); //obj1,myfunc,obj3
alert(arr[1]); //myfunc
2 . 形参与局部变量重名情况的处理。
function myfunc(a){
alert(a); //hello
var a = a+'world';
var b = a;
alert(a); //helloworld
alert(b); //helloworld
}
myfunc("hello");
由于“变量声明提升”,当执行到第一个alert(a)时,形参a已经存在。局部变量a只声明而未赋值,内存中还未创建局部变量a。这时候alert(a),a 表示形参,所以输出“hello”。
执行var a = a+‘world’;时,右边的a是形参,左边的a是局部变量。这两个a互不干扰。但这一句执行完成后,局部变量a已经覆盖了形参a。所以后面的b=a时,a为局部变量。
综合来说,当局部变量未声明或只声明而未赋值时,内存中还没有这个变量,这时候调用的同名变量是形参。当局部变量赋值完成后,内存中已经存在这个变量,并且覆盖了同名的形参。后面再调用该变量时,就指的的局部变量了。
举例: