Javascript函数形参与实参

形参,是在定义函数时使用的参数,目的是用来接收调用该函数时传进来的实际参数。
实参:是在调用时传递给函数的参数
例如

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

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


  • 6
    点赞
  • 22
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值