您的位置:首页 > Web前端 > JavaScript

Javascript函数形参与实参

2016-07-20 14:05 363 查看
形参,是在定义函数时使用的参数,目的是用来接收调用该函数时传进来的实际参数。

实参:是在调用时传递给函数的参数

例如

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为局部变量。

综合来说,当局部变量未声明或只声明而未赋值时,内存中还没有这个变量,这时候调用的同名变量是形参。当局部变量赋值完成后,内存中已经存在这个变量,并且覆盖了同名的形参。后面再调用该变量时,就指的的局部变量了。

举例:


                                            
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: