在《Javascript权威指南》中这样定义:
参数有形参(parameter)和实参(argument)的区别,形参相当于函数中定义的变量,实参是在运行时的函数调用时传入的参数。
说明白就是,形参就是函数声明时的变量,实参是我们调用该函数时传入的具体参数。
例子:
声明函数add时,a,b就是形参。调用函数add(1,2) 1,2就是实参。
function add(a,b) { return a + b }; add(1,2);
参考涞源 //这个博客还有些文章 我需要再看看
JavaScript的参数传递也都是采用值传递的方式进行传值
1.通过实参调用函数的时候,传入函数里的是实参的副本而不是实参,因此在函数里面修改参数值并不会对实参造成影响。
例如:将全局变量作为参数传到函数内部修改之后并不影响变量自己
// 这一条只对普通数据类型有效 ,对引用类型无效(引用类型的重写不影响全局,但是如果是部分操作就会影响,例如 array.push)
function test(value) { //修改value的值 value.push('part'); alert("函数内部的变量值:"+value);//局部变量 } var value = ['global']; test(value); alert("函数外部的值:"+value)//全局变量 VM398:6 alert: 函数内部的变量值:global,part VM398:11 alert: 函数外部的值:global,part
function test(value) { //修改value的值 value = "局部变量"; alert("函数内部的变量值:"+value);//局部变量 } var value = "全局变量"; test(value); alert("函数外部的值:"+value)//全局变量 VM408:6 alert: 函数内部的变量值:局部变量 VM408:11 alert: 函数外部的值:全局变量 //普通数据类型 互不影响
(2)函数的参数个数问题:
使用空参数没有任何问题,程序可以正常执行,只是JS没有传入实参的参数值将作为undefined处理
function f() {console.log(arguments[0])} undefined f() VM617:1 undefined
JavaScript调用函数时对传入的实参并没有要求,即使定义函数时声明了多个形参,调用函数时也不要求必须传入相匹配的实参。因此JavaScript不存在函数重载;对JavaScript来说函数名字是唯一的标识类。
函数重载,就是函数名称一样,但是输入输出不一样。或者说,允许某个函数有各种不同输入,根据不同的输入,调用不同的函数,然后返回不同的结果。
例如:如果定义两个名字相同的函数,不管参数个数,后面的函数会覆盖前面定义的函数:
没有传入的参数会被当为null和undefined处理
<script> function test(para1) { alert(para1 == null);//true alert(para1 == undefined);//true } test(); </script>
在JavaScript中,将一个变量赋值为undefined或null,老实说,几乎没区别。