标签: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>
本文出自 “11721999” 博客,请务必保留此出处http://11731999.blog.51cto.com/11721999/1831562
标签:html5 js
原文地址:http://11731999.blog.51cto.com/11721999/1831562