JavaScript强化教程——对象的值传递和引用传递

本文为 H5EDU 机构官方 HTML5培训 教程,主要介绍:JavaScript强化教程——对象的值传递和引用传递
 

function SetName(obj){ 
obj.name="Tom";//执行之前,此时的obj和Person的name属性均为undefined 
obj1=new Object(); 
obj1=obj;//声明一个全局对象,那么obj、obj1和Person此时应该是同一个对象 
}//SetName函数执行完之后,obj对象销毁,其余对象仍然存在 
Person=new Object();//声明Person对象 
SetName(Person);//调用SetName函数并将对象作为参数传入 
obj1.name="Lucy";//通过obj1改变Person的name属性 
alert(Person.name);//输出“Lucy”,左边的代码结论给的感觉是,JavaScript的对象就是按引用传递
/*
我想知道在调用SetName(Person)的时候,Person传递到function SetName(obj)位置到底是值传递
还是引用传递,如果按照如下的说法-->摘抄至JavaScript高级教程(第三版)
function SetName(obj){
obj.name="Tom";
obj=new Object();
obj.name="Lucy";
}
Person=new Object();//声明Person对象
SetName(Person);//
alert(Person.name);//输出Tom
我感觉调用函数的时候Person和obj应该是用一个引用,但是是将function中的obj局部对象重新声明,我觉得在执行了obj=new Object()重新声明对象这个语句之后,
此时的obj和调用SetName(Person)的Person对象是不同的引用(地址), obj.name="Lucy";这句话对Person此时根本就没有起作用,所以才会有书中的结论,输出为“Tom"的结果,所以,我觉得书中的这个代码还是不足以证明JavaScript中对象是按值传递的这个结论,
我想请问如何去理解这个问题,谢谢大家*/

再附上网上找的一段代码,在调用函数输入的都是对象,为什么有不同的结果:
<script type="text/javascript">
function foo(v3){
v3={a:3};
alert(v3.a);//3
}
var v4={};
foo(v4);
alert(v4.a);//undefined
</script>
<script type="text/javascript">
function fooled(v2){
v2.b=4;
alert(v2.b);//4
}
var v1=new Object();
fooled(v1);
alert(v1.b);//4
</script>
点击进入JS强化教程:http://www.h5edu.cn/htm/step/h5edu_44.html
    原文作者:zhanyingwang
    原文地址: http://www.cnblogs.com/zhanyingwang/p/5717169.html
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞