本文和大家分享的主要是javascript中参数按值传递相关内容,一起来看看吧,希望对大家学习javascript有所帮助。 除了按值传递、引用传递,还有第三种传递方式 —— 按共享传递 定义 在《JavaScript高级程序设计》第三版4.1.3,讲到传递参数: ECMAScript中所有函数的参数都是按值传递的。 什么是按值传递呢? 也就是说,把函数外部的值复制给函数内部的参数,就和把值从一个变量复制到另一个变量一样。 按值传递 好像很好理解的样子。 让我们看个例子: var value = 1;function foo(v) { v = 2; console.log(v); //2 } foo(value);console.log(value) // 1 很好理解,当传递value到函数foo中,相当于拷贝了一份value,假设拷贝的这份叫_value,函数中修改的都是_value的值,而不会影响原来的value值。 引用传递 拷贝虽然很好理解,但是当值是一个复杂的数据结构的时候,拷贝就会产生性能上的问题。 所以还有另一种传递方式叫做按引用传递。 所谓按引用传递,就是传递对象的引用,函数内部对参数的任何改变都会影响该对象的值,因为两者引用的是同一个对象。 举个例子: var obj = { value: 1 };function foo(o) { o.value = 2; console.log(o.value); //2 } foo(obj);console.log(obj.value) // 2 嗯,这就是引用传递! 第三种传递方式 哎,不对啊,明明都说了ECMAScript中所有函数的参数都是按值传递的,这怎么按引用传递成功了!? 不急, 让我们再看个例子: var obj = { value: 1 };function foo(o) { o = 2; console.log(o); //2 } foo(obj);console.log(obj.value) // 1 咦,如果是引用传递的话,外层的值也会被修改呐,这怎么又没被改呢?所以不是引用传递吗? 这就要讲到其实还有第三种传递方式,叫按共享传递。 而共享传递是指,在传递对象的时候,传递对象的引用的副本 注意: 按引用传递是传递对象的引用,而按共享传递是传递对象的引用的副本! 所以修改o.value,可以通过引用找到原值,但是直接修改o,并不会修改原值。 所以,你可以理解为: 参数如果是基本类型是按值传递,如果是引用类型按共享传递。 但是因为拷贝副本也是一种值的拷贝,所以在高程中也直接认为是按值传递了。 所以,高程,谁叫你是红宝书嘞! 来源:稀土掘金 |