javascript值传递和引用传递的问题,代码如下

functiontest1(){vara={}varb=a;a['com']={};a={};a['test']={};a={};a['momo']={};a={};co... function test1(){
var a={}
var b=a;
a['com']={};
a={};
a['test']={};
a={};
a['momo']={};
a={};
console.log(a)
console.log(b)
}

function test2(){
var a={}
var b=a;
a['com']={};
a['test']={};
a['momo']={};
console.log(a)
console.log(b)
}
test1中b的结果是{com:{}};
test2中b的结果{com:{},test:{},momo:{}}
想问一下test1中b的结果为什么是{com:{}}?test2和test1有什么区别吗?
展开
 我来答
魏蕤
2013-08-19 · TA获得超过426个赞
知道小有建树答主
回答量:231
采纳率:0%
帮助的人:241万
展开全部

这里涉及到javascript变量赋值的问题。首先解释一下,变量赋值的两种情况,一种是基本数据类型如(number类型、boolean类型等),一种则是引用类型如({},[],function等)。前者变量持有的值,后者持有对象的引用。何谓对象的引用,比较浅显地说就是指向存储对象地址值。当多个变量持有同一引用时,通过它们的任何一个都可以改变对象。比如

var a;
var b;
b = a = {value: 'Hello World'};//b和a持有相同引用
a.value = 'Good morning';//通过a向对象添加属性,b也可访问得到
alert(b.value);//输出Good morning

理解了上面,就好解释楼主的代码了,现在一一解析,注意看代码后面的注释

function test1(){
  var a={};//变量a持有一个空对象的引用
  var b=a;//变量b、a持有一个相同的引用
  a['com']={};//通过变量a向对象添加属性,由于b与a持有引用相同,所以b也可访问到com
  a={};//变量a持有另一个空对象引用,此时b和a引用不同,a添加属性不会影响到b
  a['test']={};//由于a和b引用不同,这里添加test属性,b是访问不到的。
  a={};//变量持有另一个空引用,此时b和a引用还是不同,后面的道理同上。
  a['momo']={};
  a={};
  console.log(a);//最终a={}
  console.log(b)//b={com:{}}
 }
 function test2(){
  var a={};//变量a持有一个空对象的引用
  var b=a;//变量b和a持有相同引用,所以通过a向对象添加属性,b也可以访问。
  a['com']={};
  a['test']={};
  a['momo']={};
  console.log(a);//a = b = {com:{},test:{},momo:{}}
  console.log(b);
 }

对比代码楼主应该知道,test1和test2的区别在于,变量a在test1中不断的赋值新的引用,导致a与b持有的引用不同,后面向a添加的属性,b都无法访问到。

刘海强大叔
2013-08-19
知道答主
回答量:21
采纳率:0%
帮助的人:16.9万
展开全部
javascript中的Object 和 Array 赋值 和 PHP中的 引用是一个道理, 也就是 函数中的赋值相当于引用了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式