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

查看:78
本文介绍了javascript - 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

解决方案

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

这篇关于javascript - js函数参数按值传递怎么理解?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆