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强化教程

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值