js函数参数按值传递怎么理解?

function setName(obj) { 
    obj.name = 'zjzhome'; 
    obj = new Object();
    obj.name = 'zjz' 
}

var person = new Object()

setName(person)

console.log(person.name) // zjzhome

obj=new Object()这里会发生什么?最后为什么会输出zjzhome

阅读 3.7k
3 个回答

参数是对象的时候,传递的是对象的引用的copy啊,所以第一次为obj.name赋值的时候,因为obj引用的对象和person的引用一致,所以会影响到person,但是obj = new Object()以后obj就和person引用的不是一个对象了,所以第二次赋值并不会影响person

题主的这段代码是《js高级程序设计》中4.1.3章节对“函数参数是按值传递”的解释,其实我觉得这段代码无法解释的;如果在全局环境下测试以下代码

var b=new Object();
var c=b;
c.i=1;
c=new Object();
c.i=2;
console.log(b.i)    // 1

结果是1,全局环境下对变量进行对象赋值,应该是引用赋值吧,那为什么还是1呢?那就是是说明新的对象引用赋值给变量c,b不变, c和b不再是引用同一个对象了。所以说,引用赋值,也出现这种现象。而书中说这一现象是函数参数是按值赋值,而不是引用赋值导致的,这不就是错的么,求大神点播啊。

新手上路,请多包涵

等于一个{}

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题