函数参数的传递方式

向参数传递基本类型值时,被传递的值会被复制给一个局部变量(即命名参数,或者是arguments对象中的一个元素)。
function addOne (num) {
    num++;
    return num;
}
var count = 1;
var result = addOne(count);
console.log(count); //1
console.log(result); //2
在上面的例子中,变量count的值被传递给函数的参数num以便在函数中使用,此时变量count和参数num的值虽然是一样的,但是它们是两个相互独立的变量,在函数中改变参数num的值并不会影响函数外部的变量count的值。
因此JavaScript中函数的基本类型值参数的传递是按值传递的。
引用类型值的传递
function setName (obj) {
    obj.name = ‘Nicholas’;
}
var person = new Object();
setName(person);
console.log(person.name); //’Nicholas’
在上面的例子中,变量person的值被传递给函数的参数obj,此时在函数内部为参数obj添加一个name属性,函数对参数obj的使得函数外部的变量person也获得了一个name属性。从结果上看,JavaScript中函数的引用类型值参数的传递似乎是按引用传递的。
然而并非如此。变量person的值是引用类型值,因此它的值在变量对象中可以看做是一个实际对象在内存中的地址(或指针)。传递参数以后参数obj的值是也是该对象在内存中的地址,因此在函数中操作参数obj的值所引用的对象相当于操作变量person的值所引用的对象。
function setName (obj) {
    obj.name = ‘Nicholas’;
    obj = new Object();
    obj.name = ‘Greg’;
    return obj;
}
var person = new Object();
var result = setName(person);
console.log(person.name); //’Nicholas’
console.log(result.name); //’Greg’
如果参数传递是按引用传递的,在上面的例子中,函数改变了参数obj的值所引用的对象,那么相对应的变量person的值所引用的对象也会改变。改变函数的写法或许能更加有助于理解参数的按值传递。
function setName () {
    var obj = arguments[0];
    obj.name = ‘Nicholas’;
    obj = new Object();
    obj.name = ‘Greg’;
    return obj;

}

<a href="http://jinan.changtu.com/">济南长途汽车站</a>

IT文库 » 函数参数的传递方式
分享到: 更多 (0)

评论 抢沙发

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址