码迷,mamicode.com
首页 > 编程语言 > 详细

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

时间:2016-07-29 15:51:14      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:html5 js

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

本文出自 “11721999” 博客,请务必保留此出处http://11731999.blog.51cto.com/11721999/1831562

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

标签:html5 js

原文地址:http://11731999.blog.51cto.com/11721999/1831562

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!