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有什么区别吗? 展开
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有什么区别吗? 展开
2个回答
展开全部
这里涉及到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都无法访问到。
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询