Javascript函数形参与实参
2016-07-20 14:05
363 查看
形参,是在定义函数时使用的参数,目的是用来接收调用该函数时传进来的实际参数。
实参:是在调用时传递给函数的参数
例如
这里a,b,c就是形参。1,2,3为实参。
形参和实参是不同的变量,他们在内存中处于不同的位置,形参在函数运行结束时将被释放。
主要有两点需要注意的
1 . 如果实参是引用类型(object,array等),那么对相对的形参进行更改,是否会影响到实参的值
那么最后一句:alert(obj.name);会输出什么呢,答案是func。
函数参数传递包含两种方式:值传递和引用传递。
值传递:形参是实参值的一个副本,对形参的改变不会影响实参
引用传递:形参实际上是对实参引用变量的复制,导致这实参、形参都指向同一个对象实体。形参改变会同时改变实参的值。
可以这样理解:myfunc(obj);可以看作是
举例说明:
2 . 形参与局部变量重名情况的处理。
由于“变量声明提升”,当执行到第一个alert(a)时,形参a已经存在。局部变量a只声明而未赋值,内存中还未创建局部变量a。这时候alert(a),a 表示形参,所以输出“hello”。
执行var a = a+’world’;时,右边的a是形参,左边的a是局部变量。这两个a互不干扰。但这一句执行完成后,局部变量a已经覆盖了形参a。所以后面的b=a时,a为局部变量。
综合来说,当局部变量未声明或只声明而未赋值时,内存中还没有这个变量,这时候调用的同名变量是形参。当局部变量赋值完成后,内存中已经存在这个变量,并且覆盖了同名的形参。后面再调用该变量时,就指的的局部变量了。
举例:
实参:是在调用时传递给函数的参数
例如
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为局部变量。
综合来说,当局部变量未声明或只声明而未赋值时,内存中还没有这个变量,这时候调用的同名变量是形参。当局部变量赋值完成后,内存中已经存在这个变量,并且覆盖了同名的形参。后面再调用该变量时,就指的的局部变量了。
举例:
相关文章推荐
- DataTable转Json以及Json转DataTable
- 初识javascript
- jstl c:choose>、<c:when>和<c:otherwise>标签
- JS模块化
- [HTML]js实现页面跳转,页面A跳到另一个页面B.以及页面传值(中文)
- 实现一周之内自动登录的 cookie和session还有localStorage的存储机制
- js修改:before、:after的内容
- js 获取时间 格式化输出
- 在C#中,Json的序列化和反序列化的几种方式总结
- JsonCpp使用简介
- Javascript刷新页面
- JSP学习笔记2
- js页面跳转
- JS正则表达式速查
- JavaScript random方法得到随机整数
- DOM(一)一些属性方法介绍以及兼容性问题
- javascript arguments解释,实现可变长参数。
- wordpress如何屏蔽wp-json(禁用REST API)
- Json.Net组件指定/忽略序列化字段属性技巧知识点
- js只执行1次的函数示例