函数参数解析

在《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,老实说,几乎没区别。

猜你喜欢

转载自www.cnblogs.com/-constructor/p/12357035.html