javascript传递参数

ECMAScript中所有函数的参数都是 按值传递的,也就是说,把函数外部的值复制给函数内部的参数,就和把值从一个变量复制到另一个变量中一样。 访问变量有按值和按引用的两种 方式,而参数只能按值传递。

在向参数传递基本类型的值时,被传递的值会被复制给一个局部变量(即命名参数,或者就是arguments对象中的一个元素)。在向参数传递引用类型的值时,会把这个值在内存中的地址复制给一个局部变量,因此这个局部变量的变化反映在函数的外部。例子

        function addTen(num) {
            num += 10;
            return num;
        }
        var count = 20;
        var result = addTen(count);
        alert(count); //20,没有变化
        alert(result); //30

这里的函数addTen()有一个参数num,而实际上是函数的局部变量。在调用这个函数时,变量count作为参数被传递给函数,这个变量的值是20.于是,数值20被复制给参数num以便在addTen()中使用。在函数内部,参数num的值被加上了10,但这一变化不会影响函数外部的count 变量。参数num与count互不相识,它们仅仅是具有相同的值。再用对象来看一例子:

        function setName(obj) {
            obj.name = 'Jin';
        }
        var person = new Object();
        setName(person);
        alert(person.name); //Jin

 

参考文献<Javascript高级程序设计>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值